diff options
author | Joey Hess <joey@kitenet.net> | 2011-11-09 17:28:35 -0400 |
---|---|---|
committer | Joey Hess <joey@kitenet.net> | 2011-11-09 17:28:35 -0400 |
commit | 2934a65ac5bbab5ac127c495c8c2492e729c2b67 (patch) | |
tree | 761a2afaa84eb292edef7e4a0aea7413ff446a14 /Utility/SafeCommand.hs | |
parent | 8ce7e73f74e95276472d18816b7c6a60bab25abb (diff) |
add safeSystem
This is more safe than System.Cmd.Utils.safeSystem, since it does not throw
an error on nonzero exit status.
Diffstat (limited to 'Utility/SafeCommand.hs')
-rw-r--r-- | Utility/SafeCommand.hs | 20 |
1 files changed, 15 insertions, 5 deletions
diff --git a/Utility/SafeCommand.hs b/Utility/SafeCommand.hs index ba9362603..aedf27137 100644 --- a/Utility/SafeCommand.hs +++ b/Utility/SafeCommand.hs @@ -13,6 +13,7 @@ import System.Posix.Process hiding (executeFile) import System.Posix.Signals import Data.String.Utils import System.Log.Logger +import Control.Applicative {- A type for parameters passed to a shell command. A command can - be passed either some Params (multiple parameters can be included, @@ -36,14 +37,23 @@ toCommand = (>>= unwrap) {- Run a system command, and returns True or False - if it succeeded or failed. - - - - SIGINT(ctrl-c) is allowed to propigate and will terminate the program. -} boolSystem :: FilePath -> [CommandParam] -> IO Bool boolSystem command params = boolSystemEnv command params Nothing boolSystemEnv :: FilePath -> [CommandParam] -> Maybe [(String, String)] -> IO Bool -boolSystemEnv command params env = do +boolSystemEnv command params env = dispatch <$> safeSystemEnv command params env + where + dispatch ExitSuccess = True + dispatch _ = False + +{- Runs a system command, returning the exit status. -} +safeSystem :: FilePath -> [CommandParam] -> IO ExitCode +safeSystem command params = safeSystemEnv command params Nothing + +{- SIGINT(ctrl-c) is allowed to propigate and will terminate the program. -} +safeSystemEnv :: FilePath -> [CommandParam] -> Maybe [(String, String)] -> IO ExitCode +safeSystemEnv command params env = do -- Going low-level because all the high-level system functions -- block SIGINT etc. We need to block SIGCHLD, but allow -- SIGINT to do its default program termination. @@ -55,8 +65,8 @@ boolSystemEnv command params env = do mps <- getProcessStatus True False childpid restoresignals oldint oldset case mps of - Just (Exited ExitSuccess) -> return True - _ -> return False + Just (Exited code) -> return code + _ -> error $ "unknown error running " ++ command where restoresignals oldint oldset = do _ <- installHandler sigINT oldint Nothing |