merge haddock documentation from propellor

This commit is contained in:
Joey Hess 2015-05-27 12:39:04 -04:00
parent 05cd58959b
commit ccf307307d

View file

@ -17,16 +17,15 @@ import Data.Char
import Control.Applicative import Control.Applicative
import Prelude import Prelude
{- A type for parameters passed to a shell command. A command can -- | Parameters that can be passed to a shell command.
- be passed either some Params (multiple parameters can be included, data CommandParam
- whitespace-separated, or a single Param (for when parameters contain = Params String -- ^ Contains multiple parameters, separated by whitespace
- whitespace), or a File. | Param String -- ^ A single parameter
-} | File FilePath -- ^ The name of a file
data CommandParam = Params String | Param String | File FilePath
deriving (Eq, Show, Ord) deriving (Eq, Show, Ord)
{- Used to pass a list of CommandParams to a function that runs -- | Used to pass a list of CommandParams to a function that runs
- a command and expects Strings. -} -- a command and expects Strings. -}
toCommand :: [CommandParam] -> [String] toCommand :: [CommandParam] -> [String]
toCommand = concatMap unwrap toCommand = concatMap unwrap
where where
@ -43,9 +42,10 @@ toCommand = concatMap unwrap
-- path separator on Windows. -- path separator on Windows.
pathseps = pathSeparator:"./" pathseps = pathSeparator:"./"
{- Run a system command, and returns True or False -- | Run a system command, and returns True or False if it succeeded or failed.
- if it succeeded or failed. --
-} -- This and other command running functions in this module log the commands
-- run at debug level, using System.Log.Logger.
boolSystem :: FilePath -> [CommandParam] -> IO Bool boolSystem :: FilePath -> [CommandParam] -> IO Bool
boolSystem command params = boolSystem' command params id boolSystem command params = boolSystem' command params id
@ -59,7 +59,7 @@ boolSystemEnv :: FilePath -> [CommandParam] -> Maybe [(String, String)] -> IO Bo
boolSystemEnv command params environ = boolSystem' command params $ boolSystemEnv command params environ = boolSystem' command params $
\p -> p { env = environ } \p -> p { env = environ }
{- Runs a system command, returning the exit status. -} -- | Runs a system command, returning the exit status.
safeSystem :: FilePath -> [CommandParam] -> IO ExitCode safeSystem :: FilePath -> [CommandParam] -> IO ExitCode
safeSystem command params = safeSystem' command params id safeSystem command params = safeSystem' command params id
@ -74,23 +74,22 @@ safeSystemEnv :: FilePath -> [CommandParam] -> Maybe [(String, String)] -> IO Ex
safeSystemEnv command params environ = safeSystem' command params $ safeSystemEnv command params environ = safeSystem' command params $
\p -> p { env = environ } \p -> p { env = environ }
{- Wraps a shell command line inside sh -c, allowing it to be run in a -- | Wraps a shell command line inside sh -c, allowing it to be run in a
- login shell that may not support POSIX shell, eg csh. -} -- login shell that may not support POSIX shell, eg csh.
shellWrap :: String -> String shellWrap :: String -> String
shellWrap cmdline = "sh -c " ++ shellEscape cmdline shellWrap cmdline = "sh -c " ++ shellEscape cmdline
{- Escapes a filename or other parameter to be safely able to be exposed to -- | Escapes a filename or other parameter to be safely able to be exposed to
- the shell. -- the shell.
- --
- This method works for POSIX shells, as well as other shells like csh. -- This method works for POSIX shells, as well as other shells like csh.
-}
shellEscape :: String -> String shellEscape :: String -> String
shellEscape f = "'" ++ escaped ++ "'" shellEscape f = "'" ++ escaped ++ "'"
where where
-- replace ' with '"'"' -- replace ' with '"'"'
escaped = join "'\"'\"'" $ split "'" f escaped = join "'\"'\"'" $ split "'" f
{- Unescapes a set of shellEscaped words or filenames. -} -- | Unescapes a set of shellEscaped words or filenames.
shellUnEscape :: String -> [String] shellUnEscape :: String -> [String]
shellUnEscape [] = [] shellUnEscape [] = []
shellUnEscape s = word : shellUnEscape rest shellUnEscape s = word : shellUnEscape rest
@ -107,19 +106,19 @@ shellUnEscape s = word : shellUnEscape rest
| c == q = findword w cs | c == q = findword w cs
| otherwise = inquote q (w++[c]) cs | otherwise = inquote q (w++[c]) cs
{- For quickcheck. -} -- | For quickcheck.
prop_idempotent_shellEscape :: String -> Bool prop_idempotent_shellEscape :: String -> Bool
prop_idempotent_shellEscape s = [s] == (shellUnEscape . shellEscape) s prop_idempotent_shellEscape s = [s] == (shellUnEscape . shellEscape) s
prop_idempotent_shellEscape_multiword :: [String] -> Bool prop_idempotent_shellEscape_multiword :: [String] -> Bool
prop_idempotent_shellEscape_multiword s = s == (shellUnEscape . unwords . map shellEscape) s prop_idempotent_shellEscape_multiword s = s == (shellUnEscape . unwords . map shellEscape) s
{- Segments a list of filenames into groups that are all below the maximum -- | Segments a list of filenames into groups that are all below the maximum
- command-line length limit. -} -- command-line length limit.
segmentXargsOrdered :: [FilePath] -> [[FilePath]] segmentXargsOrdered :: [FilePath] -> [[FilePath]]
segmentXargsOrdered = reverse . map reverse . segmentXargsUnordered segmentXargsOrdered = reverse . map reverse . segmentXargsUnordered
{- Not preserving data is a little faster, and streams better when -- | Not preserving order is a little faster, and streams better when
- there are a great many filesnames. -} -- there are a great many filenames.
segmentXargsUnordered :: [FilePath] -> [[FilePath]] segmentXargsUnordered :: [FilePath] -> [[FilePath]]
segmentXargsUnordered l = go l [] 0 [] segmentXargsUnordered l = go l [] 0 []
where where