module What4.Utils.Streams
( logErrorStream
) where
import qualified Data.ByteString.UTF8 as UTF8
import qualified System.IO.Streams as Streams
logErrorStream :: Streams.InputStream UTF8.ByteString
-> (String -> IO ())
-> IO ()
logErrorStream :: InputStream ByteString -> (String -> IO ()) -> IO ()
logErrorStream InputStream ByteString
err_stream String -> IO ()
logFn = do
let write_err :: Maybe String -> IO ()
write_err Maybe String
Nothing = () -> IO ()
forall (m :: Type -> Type) a. Monad m => a -> m a
return ()
write_err (Just String
b) = String -> IO ()
logFn String
b
OutputStream String
err_output <- (Maybe String -> IO ()) -> IO (OutputStream String)
forall a. (Maybe a -> IO ()) -> IO (OutputStream a)
Streams.makeOutputStream Maybe String -> IO ()
write_err
InputStream String
lns <- (ByteString -> String)
-> InputStream ByteString -> IO (InputStream String)
forall a b. (a -> b) -> InputStream a -> IO (InputStream b)
Streams.map ByteString -> String
UTF8.toString (InputStream ByteString -> IO (InputStream String))
-> IO (InputStream ByteString) -> IO (InputStream String)
forall (m :: Type -> Type) a b. Monad m => (a -> m b) -> m a -> m b
=<< InputStream ByteString -> IO (InputStream ByteString)
Streams.lines InputStream ByteString
err_stream
InputStream String -> OutputStream String -> IO ()
forall a. InputStream a -> OutputStream a -> IO ()
Streams.connect InputStream String
lns OutputStream String
err_output