From d81cbaafde66f4b96af2f01ba56743089fd87c77 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Roman=20Smr=C5=BE?= Date: Tue, 14 Jan 2025 20:16:55 +0100 Subject: Common blink var for whole terminal output --- src/Command/Run.hs | 13 ++++--------- 1 file changed, 4 insertions(+), 9 deletions(-) (limited to 'src/Command') diff --git a/src/Command/Run.hs b/src/Command/Run.hs index bd2aba9..403e8b8 100644 --- a/src/Command/Run.hs +++ b/src/Command/Run.hs @@ -113,19 +113,14 @@ showStatus blink = \case displayStatusLine :: TerminalOutput -> Text -> Text -> [ Maybe (TVar (JobStatus JobOutput)) ] -> IO () displayStatusLine tout prefix1 prefix2 statuses = do - blinkVar <- newTVarIO False - t <- forkIO $ forever $ do - threadDelay 500000 - atomically $ writeTVar blinkVar . not =<< readTVar blinkVar line <- newLine tout "" void $ forkIO $ do - go line blinkVar "\0" - killThread t + go line "\0" where - go line blinkVar prev = do + go line prev = do (ss, cur) <- atomically $ do ss <- mapM (sequence . fmap readTVar) statuses - blink <- readTVar blinkVar + blink <- terminalBlinkStatus tout let cur = T.concat $ map (maybe " " ((" " <>) . showStatus blink)) ss when (cur == prev) retry return (ss, cur) @@ -137,4 +132,4 @@ displayStatusLine tout prefix1 prefix2 statuses = do if all (maybe True jobStatusFinished) ss then return () - else go line blinkVar cur + else go line cur -- cgit v1.2.3