{-# LANGUAGE CPP, Rank2Types #-}
{-# OPTIONS_GHC -fno-warn-tabs #-}
module Utility.Process (
module X,
CreateProcess(..),
StdHandle(..),
readProcess,
readProcess',
readProcessEnv,
writeReadProcessEnv,
forceSuccessProcess,
forceSuccessProcess',
checkSuccessProcess,
ignoreFailureProcess,
createProcessSuccess,
createProcessChecked,
createBackgroundProcess,
withHandle,
withIOHandles,
withOEHandles,
withNullHandle,
withQuietOutput,
feedWithQuietOutput,
createProcess,
waitForProcess,
startInteractiveProcess,
stdinHandle,
stdoutHandle,
stderrHandle,
ioHandles,
processHandle,
devNull,
) where
import qualified Utility.Process.Shim
import qualified Utility.Process.Shim as X hiding (CreateProcess(..), createProcess, runInteractiveProcess, readProcess, readProcessWithExitCode, system, rawSystem, runInteractiveCommand, runProcess)
import Utility.Process.Shim hiding (createProcess, readProcess, waitForProcess)
import Utility.Misc
import Utility.Exception
import System.Exit
import System.IO
import System.Log.Logger
import Control.Concurrent
import qualified Control.Exception as E
import Control.Monad
type CreateProcessRunner = forall a. CreateProcess -> ((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle) -> IO a) -> IO a
data StdHandle = StdinHandle | StdoutHandle | StderrHandle
deriving (StdHandle -> StdHandle -> Bool
(StdHandle -> StdHandle -> Bool)
-> (StdHandle -> StdHandle -> Bool) -> Eq StdHandle
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: StdHandle -> StdHandle -> Bool
== :: StdHandle -> StdHandle -> Bool
$c/= :: StdHandle -> StdHandle -> Bool
/= :: StdHandle -> StdHandle -> Bool
Eq)
readProcess :: FilePath -> [String] -> IO String
readProcess :: FilePath -> [FilePath] -> IO FilePath
readProcess FilePath
cmd [FilePath]
args = FilePath
-> [FilePath] -> Maybe [(FilePath, FilePath)] -> IO FilePath
readProcessEnv FilePath
cmd [FilePath]
args Maybe [(FilePath, FilePath)]
forall a. Maybe a
Nothing
readProcessEnv :: FilePath -> [String] -> Maybe [(String, String)] -> IO String
readProcessEnv :: FilePath
-> [FilePath] -> Maybe [(FilePath, FilePath)] -> IO FilePath
readProcessEnv FilePath
cmd [FilePath]
args Maybe [(FilePath, FilePath)]
environ = CreateProcess -> IO FilePath
readProcess' CreateProcess
p
where
p :: CreateProcess
p = (FilePath -> [FilePath] -> CreateProcess
proc FilePath
cmd [FilePath]
args)
{ std_out = CreatePipe
, env = environ
}
readProcess' :: CreateProcess -> IO String
readProcess' :: CreateProcess -> IO FilePath
readProcess' CreateProcess
p = StdHandle
-> CreateProcessRunner
-> CreateProcess
-> (Handle -> IO FilePath)
-> IO FilePath
forall a.
StdHandle
-> CreateProcessRunner -> CreateProcess -> (Handle -> IO a) -> IO a
withHandle StdHandle
StdoutHandle CreateProcess
-> ((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO a)
-> IO a
CreateProcessRunner
createProcessSuccess CreateProcess
p ((Handle -> IO FilePath) -> IO FilePath)
-> (Handle -> IO FilePath) -> IO FilePath
forall a b. (a -> b) -> a -> b
$ \Handle
h -> do
output <- Handle -> IO FilePath
hGetContentsStrict Handle
h
hClose h
return output
writeReadProcessEnv
:: FilePath
-> [String]
-> Maybe [(String, String)]
-> (Maybe (Handle -> IO ()))
-> (Maybe (Handle -> IO ()))
-> IO String
writeReadProcessEnv :: FilePath
-> [FilePath]
-> Maybe [(FilePath, FilePath)]
-> Maybe (Handle -> IO ())
-> Maybe (Handle -> IO ())
-> IO FilePath
writeReadProcessEnv FilePath
cmd [FilePath]
args Maybe [(FilePath, FilePath)]
environ Maybe (Handle -> IO ())
writestdin Maybe (Handle -> IO ())
adjusthandle = do
(Just inh, Just outh, _, pid) <- CreateProcess
-> IO (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
createProcess CreateProcess
p
maybe (return ()) (\Handle -> IO ()
a -> Handle -> IO ()
a Handle
inh) adjusthandle
maybe (return ()) (\Handle -> IO ()
a -> Handle -> IO ()
a Handle
outh) adjusthandle
output <- hGetContents outh
outMVar <- newEmptyMVar
_ <- forkIO $ E.evaluate (length output) >> putMVar outMVar ()
maybe (return ()) (\Handle -> IO ()
a -> Handle -> IO ()
a Handle
inh IO () -> IO () -> IO ()
forall a b. IO a -> IO b -> IO b
forall (m :: * -> *) a b. Monad m => m a -> m b -> m b
>> Handle -> IO ()
hFlush Handle
inh) writestdin
hClose inh
takeMVar outMVar
hClose outh
forceSuccessProcess p pid
return output
where
p :: CreateProcess
p = (FilePath -> [FilePath] -> CreateProcess
proc FilePath
cmd [FilePath]
args)
{ std_in = CreatePipe
, std_out = CreatePipe
, std_err = Inherit
, env = environ
}
forceSuccessProcess :: CreateProcess -> ProcessHandle -> IO ()
forceSuccessProcess :: CreateProcess -> ProcessHandle -> IO ()
forceSuccessProcess CreateProcess
p ProcessHandle
pid = ProcessHandle -> IO ExitCode
waitForProcess ProcessHandle
pid IO ExitCode -> (ExitCode -> IO ()) -> IO ()
forall a b. IO a -> (a -> IO b) -> IO b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= CreateProcess -> ExitCode -> IO ()
forceSuccessProcess' CreateProcess
p
forceSuccessProcess' :: CreateProcess -> ExitCode -> IO ()
forceSuccessProcess' :: CreateProcess -> ExitCode -> IO ()
forceSuccessProcess' CreateProcess
_ ExitCode
ExitSuccess = () -> IO ()
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return ()
forceSuccessProcess' CreateProcess
p (ExitFailure Int
n) = FilePath -> IO ()
forall a. FilePath -> IO a
forall (m :: * -> *) a. MonadFail m => FilePath -> m a
fail (FilePath -> IO ()) -> FilePath -> IO ()
forall a b. (a -> b) -> a -> b
$
CreateProcess -> FilePath
showCmd CreateProcess
p FilePath -> FilePath -> FilePath
forall a. [a] -> [a] -> [a]
++ FilePath
" exited " FilePath -> FilePath -> FilePath
forall a. [a] -> [a] -> [a]
++ Int -> FilePath
forall a. Show a => a -> FilePath
show Int
n
checkSuccessProcess :: ProcessHandle -> IO Bool
checkSuccessProcess :: ProcessHandle -> IO Bool
checkSuccessProcess ProcessHandle
pid = do
code <- ProcessHandle -> IO ExitCode
waitForProcess ProcessHandle
pid
return $ code == ExitSuccess
ignoreFailureProcess :: ProcessHandle -> IO Bool
ignoreFailureProcess :: ProcessHandle -> IO Bool
ignoreFailureProcess ProcessHandle
pid = do
IO ExitCode -> IO ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (IO ExitCode -> IO ()) -> IO ExitCode -> IO ()
forall a b. (a -> b) -> a -> b
$ ProcessHandle -> IO ExitCode
waitForProcess ProcessHandle
pid
Bool -> IO Bool
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Bool
True
createProcessSuccess :: CreateProcessRunner
createProcessSuccess :: CreateProcessRunner
createProcessSuccess CreateProcess
p (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle) -> IO a
a = (ProcessHandle -> IO ()) -> CreateProcessRunner
forall b. (ProcessHandle -> IO b) -> CreateProcessRunner
createProcessChecked (CreateProcess -> ProcessHandle -> IO ()
forceSuccessProcess CreateProcess
p) CreateProcess
p (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle) -> IO a
a
createProcessChecked :: (ProcessHandle -> IO b) -> CreateProcessRunner
createProcessChecked :: forall b. (ProcessHandle -> IO b) -> CreateProcessRunner
createProcessChecked ProcessHandle -> IO b
checker CreateProcess
p (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle) -> IO a
a = do
t@(_, _, _, pid) <- CreateProcess
-> IO (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
createProcess CreateProcess
p
r <- tryNonAsync $ a t
_ <- checker pid
either E.throw return r
createBackgroundProcess :: CreateProcessRunner
createBackgroundProcess :: CreateProcessRunner
createBackgroundProcess CreateProcess
p (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle) -> IO a
a = (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle) -> IO a
a ((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle) -> IO a)
-> IO (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO a
forall (m :: * -> *) a b. Monad m => (a -> m b) -> m a -> m b
=<< CreateProcess
-> IO (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
createProcess CreateProcess
p
withHandle
:: StdHandle
-> CreateProcessRunner
-> CreateProcess
-> (Handle -> IO a)
-> IO a
withHandle :: forall a.
StdHandle
-> CreateProcessRunner -> CreateProcess -> (Handle -> IO a) -> IO a
withHandle StdHandle
h CreateProcessRunner
creator CreateProcess
p Handle -> IO a
a = CreateProcess
-> ((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO a)
-> IO a
CreateProcessRunner
creator CreateProcess
p' (((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO a)
-> IO a)
-> ((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO a)
-> IO a
forall a b. (a -> b) -> a -> b
$ Handle -> IO a
a (Handle -> IO a)
-> ((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> Handle)
-> (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle) -> Handle
select
where
base :: CreateProcess
base = CreateProcess
p
{ std_in = Inherit
, std_out = Inherit
, std_err = Inherit
}
((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle) -> Handle
select, CreateProcess
p') = case StdHandle
h of
StdHandle
StdinHandle -> ((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle) -> Handle
stdinHandle, CreateProcess
base { std_in = CreatePipe })
StdHandle
StdoutHandle -> ((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle) -> Handle
stdoutHandle, CreateProcess
base { std_out = CreatePipe })
StdHandle
StderrHandle -> ((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle) -> Handle
stderrHandle, CreateProcess
base { std_err = CreatePipe })
withIOHandles
:: CreateProcessRunner
-> CreateProcess
-> ((Handle, Handle) -> IO a)
-> IO a
withIOHandles :: forall a.
CreateProcessRunner
-> CreateProcess -> ((Handle, Handle) -> IO a) -> IO a
withIOHandles CreateProcessRunner
creator CreateProcess
p (Handle, Handle) -> IO a
a = CreateProcess
-> ((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO a)
-> IO a
CreateProcessRunner
creator CreateProcess
p' (((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO a)
-> IO a)
-> ((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO a)
-> IO a
forall a b. (a -> b) -> a -> b
$ (Handle, Handle) -> IO a
a ((Handle, Handle) -> IO a)
-> ((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> (Handle, Handle))
-> (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> (Handle, Handle)
ioHandles
where
p' :: CreateProcess
p' = CreateProcess
p
{ std_in = CreatePipe
, std_out = CreatePipe
, std_err = Inherit
}
withOEHandles
:: CreateProcessRunner
-> CreateProcess
-> ((Handle, Handle) -> IO a)
-> IO a
withOEHandles :: forall a.
CreateProcessRunner
-> CreateProcess -> ((Handle, Handle) -> IO a) -> IO a
withOEHandles CreateProcessRunner
creator CreateProcess
p (Handle, Handle) -> IO a
a = CreateProcess
-> ((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO a)
-> IO a
CreateProcessRunner
creator CreateProcess
p' (((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO a)
-> IO a)
-> ((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO a)
-> IO a
forall a b. (a -> b) -> a -> b
$ (Handle, Handle) -> IO a
a ((Handle, Handle) -> IO a)
-> ((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> (Handle, Handle))
-> (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> (Handle, Handle)
oeHandles
where
p' :: CreateProcess
p' = CreateProcess
p
{ std_in = Inherit
, std_out = CreatePipe
, std_err = CreatePipe
}
withNullHandle :: (Handle -> IO a) -> IO a
withNullHandle :: forall a. (Handle -> IO a) -> IO a
withNullHandle = FilePath -> IOMode -> (Handle -> IO a) -> IO a
forall r. FilePath -> IOMode -> (Handle -> IO r) -> IO r
withFile FilePath
devNull IOMode
WriteMode
withQuietOutput
:: CreateProcessRunner
-> CreateProcess
-> IO ()
withQuietOutput :: CreateProcessRunner -> CreateProcess -> IO ()
withQuietOutput CreateProcessRunner
creator CreateProcess
p = (Handle -> IO ()) -> IO ()
forall a. (Handle -> IO a) -> IO a
withNullHandle ((Handle -> IO ()) -> IO ()) -> (Handle -> IO ()) -> IO ()
forall a b. (a -> b) -> a -> b
$ \Handle
nullh -> do
let p' :: CreateProcess
p' = CreateProcess
p
{ std_out = UseHandle nullh
, std_err = UseHandle nullh
}
CreateProcess
-> ((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO ())
-> IO ()
CreateProcessRunner
creator CreateProcess
p' (((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO ())
-> IO ())
-> ((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO ())
-> IO ()
forall a b. (a -> b) -> a -> b
$ IO ()
-> (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO ()
forall a b. a -> b -> a
const (IO ()
-> (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO ())
-> IO ()
-> (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO ()
forall a b. (a -> b) -> a -> b
$ () -> IO ()
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return ()
feedWithQuietOutput
:: CreateProcessRunner
-> CreateProcess
-> (Handle -> IO a)
-> IO a
feedWithQuietOutput :: forall a.
CreateProcessRunner -> CreateProcess -> (Handle -> IO a) -> IO a
feedWithQuietOutput CreateProcessRunner
creator CreateProcess
p Handle -> IO a
a = FilePath -> IOMode -> (Handle -> IO a) -> IO a
forall r. FilePath -> IOMode -> (Handle -> IO r) -> IO r
withFile FilePath
devNull IOMode
WriteMode ((Handle -> IO a) -> IO a) -> (Handle -> IO a) -> IO a
forall a b. (a -> b) -> a -> b
$ \Handle
nullh -> do
let p' :: CreateProcess
p' = CreateProcess
p
{ std_in = CreatePipe
, std_out = UseHandle nullh
, std_err = UseHandle nullh
}
CreateProcess
-> ((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO a)
-> IO a
CreateProcessRunner
creator CreateProcess
p' (((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO a)
-> IO a)
-> ((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO a)
-> IO a
forall a b. (a -> b) -> a -> b
$ Handle -> IO a
a (Handle -> IO a)
-> ((Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> Handle)
-> (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> IO a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle) -> Handle
stdinHandle
devNull :: FilePath
#ifndef mingw32_HOST_OS
devNull :: FilePath
devNull = FilePath
"/dev/null"
#else
devNull = "\\\\.\\NUL"
#endif
type HandleExtractor = (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle) -> Handle
stdinHandle :: HandleExtractor
stdinHandle :: (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle) -> Handle
stdinHandle (Just Handle
h, Maybe Handle
_, Maybe Handle
_, ProcessHandle
_) = Handle
h
stdinHandle (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
_ = FilePath -> Handle
forall a. HasCallStack => FilePath -> a
error FilePath
"expected stdinHandle"
stdoutHandle :: HandleExtractor
stdoutHandle :: (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle) -> Handle
stdoutHandle (Maybe Handle
_, Just Handle
h, Maybe Handle
_, ProcessHandle
_) = Handle
h
stdoutHandle (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
_ = FilePath -> Handle
forall a. HasCallStack => FilePath -> a
error FilePath
"expected stdoutHandle"
stderrHandle :: HandleExtractor
stderrHandle :: (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle) -> Handle
stderrHandle (Maybe Handle
_, Maybe Handle
_, Just Handle
h, ProcessHandle
_) = Handle
h
stderrHandle (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
_ = FilePath -> Handle
forall a. HasCallStack => FilePath -> a
error FilePath
"expected stderrHandle"
ioHandles :: (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle) -> (Handle, Handle)
ioHandles :: (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> (Handle, Handle)
ioHandles (Just Handle
hin, Just Handle
hout, Maybe Handle
_, ProcessHandle
_) = (Handle
hin, Handle
hout)
ioHandles (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
_ = FilePath -> (Handle, Handle)
forall a. HasCallStack => FilePath -> a
error FilePath
"expected ioHandles"
oeHandles :: (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle) -> (Handle, Handle)
oeHandles :: (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> (Handle, Handle)
oeHandles (Maybe Handle
_, Just Handle
hout, Just Handle
herr, ProcessHandle
_) = (Handle
hout, Handle
herr)
oeHandles (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
_ = FilePath -> (Handle, Handle)
forall a. HasCallStack => FilePath -> a
error FilePath
"expected oeHandles"
processHandle :: (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle) -> ProcessHandle
processHandle :: (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
-> ProcessHandle
processHandle (Maybe Handle
_, Maybe Handle
_, Maybe Handle
_, ProcessHandle
pid) = ProcessHandle
pid
showCmd :: CreateProcess -> String
showCmd :: CreateProcess -> FilePath
showCmd = CmdSpec -> FilePath
go (CmdSpec -> FilePath)
-> (CreateProcess -> CmdSpec) -> CreateProcess -> FilePath
forall b c a. (b -> c) -> (a -> b) -> a -> c
. CreateProcess -> CmdSpec
cmdspec
where
go :: CmdSpec -> FilePath
go (ShellCommand FilePath
s) = FilePath
s
go (RawCommand FilePath
c [FilePath]
ps) = FilePath
c FilePath -> FilePath -> FilePath
forall a. [a] -> [a] -> [a]
++ FilePath
" " FilePath -> FilePath -> FilePath
forall a. [a] -> [a] -> [a]
++ [FilePath] -> FilePath
forall a. Show a => a -> FilePath
show [FilePath]
ps
startInteractiveProcess
:: FilePath
-> [String]
-> Maybe [(String, String)]
-> IO (ProcessHandle, Handle, Handle)
startInteractiveProcess :: FilePath
-> [FilePath]
-> Maybe [(FilePath, FilePath)]
-> IO (ProcessHandle, Handle, Handle)
startInteractiveProcess FilePath
cmd [FilePath]
args Maybe [(FilePath, FilePath)]
environ = do
let p :: CreateProcess
p = (FilePath -> [FilePath] -> CreateProcess
proc FilePath
cmd [FilePath]
args)
{ std_in = CreatePipe
, std_out = CreatePipe
, std_err = Inherit
, env = environ
}
(Just from, Just to, _, pid) <- CreateProcess
-> IO (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
createProcess CreateProcess
p
return (pid, to, from)
createProcess :: CreateProcess -> IO (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
createProcess :: CreateProcess
-> IO (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
createProcess CreateProcess
p = do
CreateProcess -> IO ()
debugProcess CreateProcess
p
CreateProcess
-> IO (Maybe Handle, Maybe Handle, Maybe Handle, ProcessHandle)
Utility.Process.Shim.createProcess CreateProcess
p
debugProcess :: CreateProcess -> IO ()
debugProcess :: CreateProcess -> IO ()
debugProcess CreateProcess
p = FilePath -> FilePath -> IO ()
debugM FilePath
"Utility.Process" (FilePath -> IO ()) -> FilePath -> IO ()
forall a b. (a -> b) -> a -> b
$ [FilePath] -> FilePath
unwords
[ FilePath
action FilePath -> FilePath -> FilePath
forall a. [a] -> [a] -> [a]
++ FilePath
":"
, CreateProcess -> FilePath
showCmd CreateProcess
p
]
where
action :: FilePath
action
| StdStream -> Bool
piped (CreateProcess -> StdStream
std_in CreateProcess
p) Bool -> Bool -> Bool
&& StdStream -> Bool
piped (CreateProcess -> StdStream
std_out CreateProcess
p) = FilePath
"chat"
| StdStream -> Bool
piped (CreateProcess -> StdStream
std_in CreateProcess
p) = FilePath
"feed"
| StdStream -> Bool
piped (CreateProcess -> StdStream
std_out CreateProcess
p) = FilePath
"read"
| Bool
otherwise = FilePath
"call"
piped :: StdStream -> Bool
piped StdStream
Inherit = Bool
False
piped StdStream
_ = Bool
True
waitForProcess :: ProcessHandle -> IO ExitCode
waitForProcess :: ProcessHandle -> IO ExitCode
waitForProcess ProcessHandle
h = do
r <- ProcessHandle -> IO ExitCode
Utility.Process.Shim.waitForProcess ProcessHandle
h
debugM "Utility.Process" ("process done " ++ show r)
return r