module BuildBox.Command.System.Internals
( streamIn
, streamOuts)
where
import System.IO
import Control.Concurrent
streamIn :: Handle -> Chan (Maybe String) -> IO ()
streamIn hRead chan
= do eof <- hIsEOF hRead
if eof
then do
writeChan chan Nothing
return ()
else do
str <- hGetLine hRead
writeChan chan (Just (str ++ "\n"))
streamIn hRead chan
streamOuts :: [(Chan (Maybe String), (Maybe Handle), QSem)] -> IO ()
streamOuts chans
= streamOuts' False [] chans
where
streamOuts' _ [] []
= return ()
streamOuts' True prev []
= streamOuts' False [] prev
streamOuts' False prev []
= do yield
streamOuts' False [] prev
streamOuts' active prev (x@(chan, mHandle, qsem) : rest)
= isEmptyChan chan >>= \empty ->
if empty
then streamOuts' active (prev ++ [x]) rest
else do
mStr <- readChan chan
case mStr of
Nothing
-> do signalQSem qsem
streamOuts' active prev rest
Just str
| Just h <- mHandle
-> do hPutStr h str
streamOuts' True (prev ++ [x]) rest
| otherwise
-> streamOuts' True (prev ++ [x]) rest