From a389a560d952d4d1298af801dbf6e078c762d50c Mon Sep 17 00:00:00 2001 From: Will Ehrendreich Date: Fri, 13 Oct 2023 10:33:09 -0500 Subject: [PATCH] feat(tee): improved tee functionality --- lua/ionide/init.lua | 28 ++++++++++++++++++++++++++-- 1 file changed, 26 insertions(+), 2 deletions(-) diff --git a/lua/ionide/init.lua b/lua/ionide/init.lua index fa9614d..cea0dec 100644 --- a/lua/ionide/init.lua +++ b/lua/ionide/init.lua @@ -1903,11 +1903,35 @@ local function getFsiCommand() and M.MergedConfig.IonideNvimSettings.EnableFsiStdOutTeeToFile and M.MergedConfig.IonideNvimSettings.EnableFsiStdOutTeeToFile == true then + local teeToInvoke = " *>&1 | tee '" + local teeToTry = [[ +$Path = "$pshome\types.ps1xml"; +[IO.StreamReader]$reader = [System.IO.StreamReader]::new($Path) +# embed loop in scriptblock: +& { + while (-not $reader.EndOfStream) + { + # read current line + $reader.ReadLine() + + # add artificial delay to pretend this was a HUGE file + Start-Sleep -Milliseconds 10 + } +# process results in real-time as they become available: +} | Out-GridView + +# close and dispose the streamreader properly: +$reader.Close() +$reader.Dispose() + + ]] + -- local teeToInvoke = [[ | ForEach-Object { tee $_ $_ } | tee ']] + local defaultOutputName = "./fsiOutputFile.txt" if M.MergedConfig.IonideNvimSettings and M.MergedConfig.IonideNvimSettings.FsiStdOutFileName then if M.MergedConfig.IonideNvimSettings.FsiStdOutFileName ~= "" then - cmd = cmd .. " | tee '" .. (M.MergedConfig.IonideNvimSettings.FsiStdOutFileName or "./fsiOutputFile.txt") .. "'" + cmd = cmd .. teeToInvoke .. (M.MergedConfig.IonideNvimSettings.FsiStdOutFileName or defaultOutputName) .. "'" else - cmd = cmd .. " | tee '" .. "./fsiOutputFile.txt" .. "'" + cmd = cmd .. teeToInvoke .. defaultOutputName .. "'" end end end