diff options
author | Joey Hess <joeyh@joeyh.name> | 2015-10-04 15:46:25 -0400 |
---|---|---|
committer | Joey Hess <joeyh@joeyh.name> | 2015-10-04 15:46:25 -0400 |
commit | b411eb441024d5f4afa360ea3ff53c9a502a86a0 (patch) | |
tree | 07a598642db1deff9779d80f05b6951205ce1a2a /Utility | |
parent | 11d7cdc840c5e30310198eb3a5c3ff39a30e2907 (diff) | |
parent | da451ad509268133fff9b2f58caebae2204b318e (diff) |
Merge branch 'winprocfix'
Diffstat (limited to 'Utility')
-rw-r--r-- | Utility/Process.hs | 12 |
1 files changed, 5 insertions, 7 deletions
diff --git a/Utility/Process.hs b/Utility/Process.hs index c4882a014..cc1138678 100644 --- a/Utility/Process.hs +++ b/Utility/Process.hs @@ -172,22 +172,21 @@ createBackgroundProcess p a = a =<< createProcess p -- returns a transcript combining its stdout and stderr, and -- whether it succeeded or failed. processTranscript :: String -> [String] -> (Maybe String) -> IO (String, Bool) -processTranscript cmd opts = processTranscript' cmd opts Nothing +processTranscript = processTranscript' id -processTranscript' :: String -> [String] -> Maybe [(String, String)] -> (Maybe String) -> IO (String, Bool) -processTranscript' cmd opts environ input = do +processTranscript' :: (CreateProcess -> CreateProcess) -> String -> [String] -> Maybe String -> IO (String, Bool) +processTranscript' modproc cmd opts input = do #ifndef mingw32_HOST_OS {- This implementation interleves stdout and stderr in exactly the order - the process writes them. -} (readf, writef) <- System.Posix.IO.createPipe readh <- System.Posix.IO.fdToHandle readf writeh <- System.Posix.IO.fdToHandle writef - p@(_, _, _, pid) <- createProcess $ + p@(_, _, _, pid) <- createProcess $ modproc $ (proc cmd opts) { std_in = if isJust input then CreatePipe else Inherit , std_out = UseHandle writeh , std_err = UseHandle writeh - , env = environ } hClose writeh @@ -199,12 +198,11 @@ processTranscript' cmd opts environ input = do return (transcript, ok) #else {- This implementation for Windows puts stderr after stdout. -} - p@(_, _, _, pid) <- createProcess $ + p@(_, _, _, pid) <- createProcess $ modproc $ (proc cmd opts) { std_in = if isJust input then CreatePipe else Inherit , std_out = CreatePipe , std_err = CreatePipe - , env = environ } getout <- mkreader (stdoutHandle p) |