module Language.Haskell.LSP.Test.Server (withServer) where
import Control.Concurrent
import Control.Exception
import Control.Monad
import Language.Haskell.LSP.Test.Compat
import System.IO
import System.Process
withServer :: String -> Bool -> (Handle -> Handle -> Int -> IO a) -> IO a
withServer serverExe logStdErr f = do
let cmd:args = words serverExe
createProc = (proc cmd args) { std_in = CreatePipe, std_out = CreatePipe, std_err = CreatePipe }
(Just serverIn, Just serverOut, Just serverErr, serverProc) <- createProcess createProc
hSetBuffering serverErr NoBuffering
errSinkThread <- forkIO $ forever $ hGetLine serverErr >>= when logStdErr . putStrLn
pid <- getProcessID serverProc
finally (f serverIn serverOut pid) $ do
killThread errSinkThread
terminateProcess serverProc