h$ 6      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~  Safe-Inferred !None 3Zturtle+A line of text (does not contain newlines).[turtleThe [* exception is thrown when you construct a Z3 using an overloaded string literal or by calling  explicitly and the supplied string contains newlines. This is a programming error to do so: if you aren't sure that the input string is newline-free, do not rely on the   Z instance.When debugging, it might be useful to look for implicit invocations of  for Z: >>> sh (do { line <- "Hello\nWorld"; echo line }) *** Exception: NewlineForbiddenIn the above example, echo expects its argument to be a Z, thus line :: Z. Since we bind line in Shell, the string literal "Hello\nWorld" has type Shell Z. The   (Shell Z)+ instance delegates the construction of a Z to the   Z) instance, where the exception is thrown.To fix the problem, use ^: >>> sh (do { line <- select (textToLines "Hello\nWorld"); echo line }) Hello World]turtleConvert a line to a text value.^turtle&Split text into lines. The inverse of _._turtle%Merge lines into a single text value.`turtleTry to convert a text value into a line. Precondition (checked): the argument does not contain newlines.aturtleConvert a text value into a line. Precondition (unchecked): the argument does not contain newlines.Z[\]^_`aZ]^_`a[\None jturtleA j stringmturtleConcatenate two j stringsnturtle Convert a j string to a print function that takes zero or more typed arguments and returns a - stringoturtlePrint a j7 string to standard output (without a trailing newline)"printf ("Hello, "%s%"!\n") "world" Hello, world!pturtlePrint a j4 string to standard err (without a trailing newline)#eprintf ("Hello, "%s%"!\n") "world" Hello, world!qturtle Create your own format specifierrturtlej any  able value format w True"True"sturtlej an  value as a signed decimal format d 25"25"format d (-25)"-25"tturtlej a  value as an unsigned decimal format u 25"25"uturtlej a " value as an unsigned octal number format o 25"31"vturtlej a  value as an unsigned hexadecimal number (without a leading "0x") format x 25"19"wturtlej a 2 using decimal notation with 6 digits of precision format f 25.1 "25.100000"xturtlej a 5 using scientific notation with 6 digits of precision format e 25.1 "2.510000e1"yturtlej a  using decimal notation for small exponents and scientific notation for large exponents format g 25.1 "25.100000"format g 123456789 "1.234568e8"format g 0.00000000001"1.000000e-11"zturtlej that inserts -format s "ABC""ABC"{turtlej that inserts a Zformat l "ABC""ABC"|turtlej a 7 into -}turtlej a P into -~turtle Convert a 'able value to any type that implements   (such as -) repr (1,2)"(1,2)"jklmnopqrstuvwxyz{|}~jklmnopqrstuvwxyz{|}~None turtle-A helpful message explaining what a flag doesThis will appear in the --help outputturtle-A brief description of what your program does2This description will appear in the header of the --help outputturtleThe name of a sub-command=This is lower-cased to create a sub-command. For example, a  of "Name" will parse name on the command line before parsing the remaining arguments using the command's subparser.turtle6The short one-character abbreviation for a flag (i.e. -n)turtle#The name of a command-line argumentThis is used to infer the long name and metavariable for the command line flag. For example, an  of "name" will create a --name flag with a NAME metavariableturtle-Parse the given options from the command lineturtleParse the given options from the command line and add additional informationExtended version of options3 with program version header and footer informationturtleThis parser returns  if the given flag is set and  if the flag is absentturtle=Build a flag-based option parser for any type by providing a --parsing functionturtleParse any type that implements turtle Parse an  as a flag-based optionturtle Parse an  as a flag-based optionturtleParse a  as a flag-based optionturtleParse a - value as a flag-based optionturtleParse a Z value as a flag-based optionturtleParse a 7 value as a flag-based optionturtleBuild a positional argument parser for any type by providing a --parsing functionturtleParse any type that implements  as a positional argumentturtle Parse an  as a positional argumentturtle Parse an  as a positional argumentturtleParse a  as a positional argumentturtleParse a - as a positional argumentturtleParse a Z as a positional argumentturtleParse a 7 as a positional argumentturtle!Create a sub-command that parses ; and then parses the rest of the command-line arguments"The sub-command will have its own  and help textturtle$Create a named group of sub-commands#3#3None >5turtle,A fully backtracking pattern that parses an 'a' from some -turtleMatch a  against a -( input, returning all possible solutionsThe  must match the entire -turtleMatch any charactermatch anyChar "1""1"match anyChar """"turtleMatches the end of input match eof "1"[] match eof ""[()]turtle Synonym for turtle6Match any character that satisfies the given predicatematch (satisfy (== '1')) "1""1"match (satisfy (== '2')) "1"""turtleMatch a specific charactermatch (char '1') "1""1"match (char '2') "1"""turtle(Match any character except the given onematch (notChar '2') "1""1"match (notChar '1') "1"""turtleMatch a specific stringmatch (text "123") "123"["123"]You can also omit the  function if you enable the OverloadedStrings extension:match "123" "123"["123"]turtle1Match a specific string in a case-insensitive wayThis only handles ASCII stringsmatch (asciiCI "abc") "ABC"["ABC"]turtle%Match any one of the given charactersmatch (oneOf "1a") "1""1"match (oneOf "2a") "1"""turtle.Match anything other than the given charactersmatch (noneOf "2a") "1""1"match (noneOf "1a") "1"""turtleMatch a whitespace charactermatch space " "" "match space "1"""turtle(Match zero or more whitespace charactersmatch spaces " "[" "]match spaces ""[""]turtle'Match one or more whitespace charactersmatch spaces1 " "[" "]match spaces1 ""[]turtleMatch the tab character ('t')match tab "\t""\t" match tab " """turtleMatch the newline character ('n')match newline "\n""\n"match newline " """turtleMatches a carriage return ('r') followed by a newline ('n')match crlf "\r\n"["\r\n"]match crlf "\n\r"[]turtleMatch an uppercase lettermatch upper "A""A"match upper "a"""turtleMatch a lowercase lettermatch lower "a""a"match lower "A"""turtleMatch a letter or digitmatch alphaNum "1""1"match alphaNum "a""a"match alphaNum "A""A"match alphaNum "."""turtleMatch a lettermatch letter "A""A"match letter "a""a"match letter "1"""turtle Match a digitmatch digit "1""1"match digit "a"""turtleMatch a hexadecimal digitmatch hexDigit "1""1"match hexDigit "A""A"match hexDigit "a""a"match hexDigit "g"""turtleMatch an octal digitmatch octDigit "1""1"match octDigit "9"""turtle Match an unsigned decimal numbermatch decimal "123"[123]match decimal "-123"[]turtle9Transform a numeric parser to accept an optional leading '+' or '-' signmatch (signed decimal) "+123"[123]match (signed decimal) "-123"[-123]match (signed decimal) "123"[123]turtle( p) succeeds if p fails and fails if p succeedsmatch (invert "A") "A"[]match (invert "A") "B"[()]match (invert "A") "AA"[()]turtleMatch a  , but return -match (once (char '1')) "1"["1"]match (once (char '1')) ""[]turtle(Use this to match the prefix of a stringmatch "A" "ABC"[]match (prefix "A") "ABC"["A"]turtle(Use this to match the suffix of a stringmatch "C" "ABC"[]match (suffix "C") "ABC"["C"]turtle*Use this to match the interior of a stringmatch "B" "ABC"[]match (has "B") "ABC"["B"]turtle;Match the entire string if it begins with the given pattern;This returns the entire string, not just the matched prefix&match (begins "A" ) "ABC"["ABC"]&match (begins ("A" *> pure "1")) "ABC"["1BC"]turtle9Match the entire string if it ends with the given pattern;This returns the entire string, not just the matched prefix$match (ends "C" ) "ABC"["ABC"]$match (ends ("C" *> pure "1")) "ABC"["AB1"]turtle8Match the entire string if it contains the given pattern=This returns the entire string, not just the interior pattern(match (contains "B" ) "ABC"["ABC"](match (contains ("B" *> pure "1")) "ABC"["A1C"]turtle2Parse 0 or more occurrences of the given charactermatch (star anyChar) "123"["123"]match (star anyChar) ""[""] See also: turtle2Parse 1 or more occurrences of the given charactermatch (plus digit) "123"["123"]match (plus digit) ""[] See also: turtlePatterns that match multiple times are greedy by default, meaning that they try to match as many times as possible. The > combinator makes a pattern match as few times as possibleThis only changes the order in which solutions are returned, by prioritizing less greedy solutions.match (prefix (selfless (some anyChar))) "123"["1","12","123"].match (prefix (some anyChar) ) "123"["123","12","1"]turtleApply the patterns in the list in order, until one of them succeeds*match (choice ["cat", "dog", "egg"]) "egg"["egg"]*match (choice ["cat", "dog", "egg"]) "cat"["cat"]*match (choice ["cat", "dog", "egg"]) "fan"[]turtleApply the given pattern a fixed number of times, collecting the resultsmatch (count 3 anyChar) "123"["123"]match (count 4 anyChar) "123"[]turtleApply the given pattern at least the given number of times, collecting the results match (lowerBounded 5 dot) "123"[] match (lowerBounded 2 dot) "123"["123"]turtleApply the given pattern 0 or more times, up to a given bound, collecting the results match (upperBounded 5 dot) "123"["123"] match (upperBounded 2 dot) "123"[]2match ((,) <$> upperBounded 2 dot <*> chars) "123"[("12","3"),("1","23")]turtleApply the given pattern a number of times restricted by given lower and upper bounds, collecting the results%match (bounded 2 5 "cat") "catcatcat"[["cat","cat","cat"]]match (bounded 2 5 "cat") "cat"[].match (bounded 2 5 "cat") "catcatcatcatcatcat"[]) could be implemented naively as follows: >bounded m n p = do x <- choice (map pure [m..n]) count x pturtleTransform a parser to a succeed with an empty value instead of failing See also: match (option "1" <> "2") "12"["12"]match (option "1" <> "2") "2"["2"]turtle(between open close p) matches 'p' in between 'open' and 'close'> pwd)FilePath "/tmp"pwd FilePath "/"turtleGet the current directoryturtleGet the home directoryturtle$Get the path pointed to by a symlinkturtleCanonicalize a pathturtleStream all immediate children of the given directory, excluding "." and ".."turtle7Stream all recursive descendents of the given directoryturtleStream the recursive descendents of a given directory between a given minimum and maximum depthturtle7Stream all recursive descendents of the given directory;This skips any directories that fail the supplied predicate !lstree = lsif (\_ -> return True)turtleMove a file or directory?Works if the two paths are on the same filesystem. If not, mv will still work when dealing with a regular file, but the operation will not be atomicturtleCreate a directory!Fails if the directory is presentturtle'Create a directory tree (equivalent to mkdir -p))Does not fail if the directory is presentturtle Copy a fileturtleCreate a symlink from one FilePath to anotherturtleReturns  if the given 7 is not a symbolic link(This comes in handy in conjunction with : lsif isNotSymbolicLinkturtle1Copy a directory tree and preserve symbolic linksturtle4Copy a directory tree and dereference symbolic linksturtle Remove a fileturtleRemove a directoryturtle'Remove a directory tree (equivalent to rm -r)Use at your own riskturtleCheck if a file existsturtleCheck if a directory existsturtleCheck if a path existsturtleTouch a file, updating the access and modification times to the current time*Creates an empty file if it does not existturtle-Update a file or directory's user permissions chmod rwo "foo.txt" -- chmod u=rw foo.txt chmod executable "foo.txt" -- chmod u+x foo.txt chmod nonwritable "foo.txt" -- chmod u-w foo.txt"The meaning of each permission is: (+r for short): For files, determines whether you can read from that file (such as with ). For directories, determines whether or not you can list the directory contents (such as with 3). Note: if a directory is not readable then , will stream an empty list of contents (+w for short): For files, determines whether you can write to that file (such as with ). For directories, determines whether you can create a new file underneath that directory. (+x for short): For files, determines whether or not that file is executable (such as with ). For directories, determines whether or not you can read or execute files underneath that directory (such as with  or )turtle*Get a file or directory's user permissionsturtle*Set a file or directory's user permissionsturtle5Copy a file or directory's permissions (analogous to chmod --reference)turtle +rturtle -rturtle +wturtle -wturtle +xturtle -xturtle -r -w -xturtle +r -w -xturtle -r +w -xturtle -r -w +xturtle +r +w -xturtle +r -w +xturtle -r +w +xturtle +r +w +xturtle:Time how long a command takes in monotonic wall clock time/Returns the duration alongside the return valueturtleGet the system's host nameturtle(Show the full path of an executable fileturtle9Show all matching executables in PATH, not just the firstturtleSleep for the given durationA numeric literal argument is interpreted as seconds. In other words,  (sleep 2.0) will sleep for two seconds.turtleExit with the given exit codeAn exit code of 0 indicates successturtle&Throw an exception using the provided - messageturtle Analogous to  in Bash6Runs the second command only if the first one returns turtle Analogous to  in Bash5Run the second command only if the first one returns turtle;Create a temporary directory underneath the given directory)Deletes the temporary directory when doneturtle6Create a temporary file underneath the given directory$Deletes the temporary file when doneNote that this provides the   of the file in order to avoid a potential race condition from the file being moved or deleted before you have a chance to open the file. The  function provides a simpler API if you don't need to worry about that possibility.turtle6Create a temporary file underneath the given directory$Deletes the temporary file when doneturtleFork a thread, acquiring an  valueturtle Wait for an  action to completeturtleRead lines of - from standard inputturtleRead lines of - from a fileturtleRead lines of - from a  turtleStream lines of - to standard outputturtleStream lines of - to a fileturtleStream lines of - to a  turtleStream lines of - to append to a fileturtleStream lines of - to standard errorturtle$Read in a stream's contents strictlyturtle Acquire a Managed read-only   from a 7turtle Acquire a Managed write-only   from a 7turtle Acquire a Managed append-only   from a 7turtleCombine the output of multiple  s, in orderturtle$Keep all lines that match the given turtle Keep every - element that matches the given turtleReplace all occurrences of a  with its - result performs substitution on a line-by-line basis, meaning that substitutions may not span multiple lines. Additionally, substitutions may occur multiple times within the same line, like the behavior of  s/.../.../g.Warning: Do not use a  that matches the empty string, since it will match an infinite number of times.  tries to detect such  s and  with an error message if they occur, but this detection is necessarily incomplete.turtleLike , but the provided substitution must match the beginning of the lineturtleLike >, but the provided substitution must match the end of the lineturtleLike :, but the provided substitution must match the entire lineturtle3Make a `Shell Text -> Shell Text` function work on 7s instead. | Ignores any paths which cannot be decoded as valid -.turtleLike , but operates in place on a 7 (analogous to sed -i)turtleLike , but operates in place on a 7turtleLike , but operates in place on a 7turtleLike , but operates in place on a 7turtleUpdate a file in place using a  transformation+For example, this is used to implement the inplace* family of utilitiesturtleSearch a directory recursively for all files matching the given turtle8Filter a shell of FilePaths according to a given patternturtle>Check if a file was last modified after a given timestampturtle?Check if a file was last modified before a given timestampturtle A Stream of "y"sturtleNumber each element of a  (starting at 0)turtle Merge two s together, element-wiseIf one  is longer than the other, the excess elements are truncatedturtleA  that endlessly emits ()turtleLimit a  to a fixed number of valuesNOTE: This is not lazy and will still consume the entire input stream. There is no way to implement a lazy version of this utility.turtleLimit a % to values that satisfy the predicateThis terminates the stream on the first value that does not satisfy the predicateturtleCache a 's output so that repeated runs of the script will reuse the result of previous runs. You must supply a 7, where the cached result will be stored.(The stored result is only reused if the  successfully ran to completion without any exceptions. Note: on some platforms Ctrl-C will flush standard input and signal end of file before killing the program, which may trick the program into "successfully" completing.turtle9Run a list of IO actions in parallel using fork and wait./view (parallel [(sleep 3) >> date, date, date])2016-12-01 17:22:10.83296 UTC2016-12-01 17:22:07.829876 UTC2016-12-01 17:22:07.829963 UTCturtle0Split a line into chunks delimited by the given turtleGet the current timeturtle%Get the time a file was last modifiedturtle%Get the size of a file or a directoryturtlej a & using a human readable representation format sz 42"42 B"format sz 2309 "2.309 KB"format sz 949203 "949.203 KB"format sz 1600000000 "1.600 GB"format sz 999999999999999999"999999.999 TB"turtle3Count the number of characters in the stream (like wc -c)This uses the convention that the elements of the stream are implicitly ended by newlines that are one character wideturtle.Count the number of words in the stream (like wc -w)turtle.Count the number of lines in the stream (like wc -l)This uses the convention that each element of the stream represents one lineturtleGet the status of a fileturtle3Size of the file in bytes. Does not follow symlinksturtleTime of last accessturtleTime of last modificationturtleTime of last status change (i.e. owner, group, link count, mode, etc.)turtle9Get the status of a file, but don't follow symbolic linksturtleReturns the result of a  that outputs a single line. Note that if no lines / more than 1 line is produced by the Shell, this function will  with an error message. main = do directory <- single (inshell "pwd" empty) print directoryturtle#Filter adjacent duplicate elements: view (uniq (select [1,1,2,1,3]))1213turtleFilter adjacent duplicates determined after applying the function to the element:view (uniqOn fst (select [(1,'a'),(1,'b'),(2,'c'),(1,'d'),(3,'e')]))(1,'a')(2,'c')(1,'d')(3,'e')turtleFilter adjacent duplicate elements determined via the given function:'view (uniqBy (==) (select [1,1,2,1,3]))1213turtle Return a new ) that discards duplicates from the input :)view (nub (select [1, 1, 2, 3, 3, 4, 3]))1234turtle Return a new  that discards duplicates determined via the given function from the input :.view (nubOn id (select [1, 1, 2, 3, 3, 4, 3]))1234turtle2Return a list of the sorted elements of the given , keeping duplicates:sort (select [1,4,2,3,3,7]) [1,2,3,3,4,7]turtle+Return a list of the elements of the given , sorted after applying the given function and keeping duplicates: sortOn id (select [1,4,2,3,3,7]) [1,2,3,3,4,7]turtle+Return a list of the elements of the given 6, sorted by the given function and keeping duplicates:sortBy (comparing fst) (select [(1,'a'),(4,'b'),(2,'c'),(3,'d'),(3,'e'),(7,'f')])1[(1,'a'),(2,'c'),(3,'d'),(3,'e'),(4,'b'),(7,'f')]turtleGroup an arbitrary stream of - into newline-delimited Zs+stdout (toLines ("ABC" <|> "DEF" <|> "GHI") ABCDEFGHIstdout (toLines empty) -- Note that this always emits at least 1 `Line`3stdout (toLines ("ABC\nDEF" <|> "" <|> "GHI\nJKL"))ABCDEFGHIJKLturtleCommandturtle ArgumentsturtleLines of standard inputturtle Exit codeturtle Command lineturtleLines of standard inputturtle Exit codeturtleCommandturtle ArgumentsturtleLines of standard inputturtle Command lineturtleLines of standard inputturtle Exit codeturtleCommandturtle ArgumentsturtleLines of standard inputturtleExit code and stdoutturtle Command lineturtleLines of standard inputturtleExit code and stdoutturtleCommandturtle ArgumentsturtleLines of standard inputturtle(Exit code, stdout, stderr)turtle Command lineturtleLines of standard inputturtle(Exit code, stdout, stderr)turtleCommandturtleLines of standard inputturtle Exit codeturtleCommandturtleLines of standard inputturtleExit code and stdoutturtleCommandturtleLines of standard inputturtleExit code and stdoutturtleCommandturtle ArgumentsturtleLines of standard inputturtleLines of standard outputturtle Command lineturtleLines of standard inputturtleLines of standard outputturtleCommandturtleLines of standard inputturtleLines of standard outputturtleCommandturtleLines of standard inputturtleLines of standard outputturtleCommandturtle ArgumentsturtleLines of standard inputturtle!Lines of either standard output () or standard error ()turtle Command lineturtleLines of standard inputturtle!Lines of either standard output () or standard error ()turtlePermissions update functionturtlePathturtleUpdated permissionsturtleParent directoryturtleDirectory name templateturtleParent directoryturtleFile name templateturtleParent directoryturtleFile name template89RSTUVWXY98YXWVUTSR32Noneturtle(Read chunks of bytes from standard input9The chunks are not necessarily aligned to line boundariesturtle Read chunks of bytes from a file9The chunks are not necessarily aligned to line boundariesturtleRead chunks of bytes from a  9The chunks are not necessarily aligned to line boundariesturtle)Stream chunks of bytes to standard output9The chunks are not necessarily aligned to line boundariesturtle Stream chunks of bytes to a file7The chunks do not need to be aligned to line boundariesturtleStream chunks of bytes to a  7The chunks do not need to be aligned to line boundariesturtle*Append chunks of bytes to append to a file7The chunks do not need to be aligned to line boundariesturtle(Stream chunks of bytes to standard error7The chunks do not need to be aligned to line boundariesturtle$Read in a stream's contents strictlyturtleRun a command using execvp, retrieving the exit codeThe command inherits stdout and stderr for the current processturtle compressed) & decompress defaultWindowBits & view"ABCDEF""ABCDEF"turtleDecompress a stream using zlib (just like the gzip command)turtle!Decode a stream of bytes as UTF8 -9NOTE: This function will throw a pure exception (i.e. an ?) if UTF8 decoding fails (mainly due to limitations in the text# package's stream decoding API)turtle!Encode a stream of bytes as UTF8 -turtleCommandturtle Argumentsturtle(Chunks of bytes written to process inputturtle Exit codeturtle Command lineturtle(Chunks of bytes written to process inputturtle Exit codeturtleCommandturtle Argumentsturtle(Chunks of bytes written to process inputturtle Command lineturtle(Chunks of bytes written to process inputturtle Exit codeturtleCommandturtle Argumentsturtle(Chunks of bytes written to process inputturtleExit code and stdoutturtle Command lineturtle(Chunks of bytes written to process inputturtleExit code and stdoutturtleCommandturtle Argumentsturtle(Chunks of bytes written to process inputturtle(Exit code, stdout, stderr)turtle Command lineturtle(Chunks of bytes written to process inputturtle(Exit code, stdout, stderr)turtleCommandturtle(Chunks of bytes written to process inputturtle Exit codeturtleCommandturtle(Chunks of bytes written to process inputturtleExit code and stdoutturtleCommandturtle(Chunks of bytes written to process inputturtleExit code and stdoutturtleCommandturtle Argumentsturtle(Chunks of bytes written to process inputturtle(Chunks of bytes read from process outputturtle Command lineturtle(Chunks of bytes written to process inputturtle(Chunks of bytes read from process outputturtleCommandturtle(Chunks of bytes written to process inputturtle(Chunks of bytes read from process outputturtleCommandturtle(Chunks of bytes written to process inputturtle(Chunks of bytes read from process outputturtleCommandturtle Argumentsturtle(Chunks of bytes written to process inputturtleChunks of either output ( ) or error ()turtle Command lineturtle(Chunks of bytes written to process inputturtleChunks of either output ( ) or error ()turtleCompression levelturtleturtle!456!456None turtleFlipped version of . () =   ExamplesApply (+1) to a list, a    and a  :Just 2 <&> (+1)Just 3[1,2,3] <&> (+1)[2,3,4]Right 3 <&> (+1)Right 4    %!"$#('&*),+-./0123789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`ajklmnopqrstuvwxyz{|}~  %!"$#('& ./017:;<=>?@ABCDEFGHIJKLMNO*),+-PQ  1None2 !"#$#%&'()*+,-./.0.1234567689:;<=>?@ABCDEFDEFDEGDEGHIJKLMKLNKLOKLPKLQRSTUVWUVWUVXYZ[\]^\]_Y`aY`bY`cY`dYefYegYehYeiYejYekYelYemYenYeoYepYeqYerYesYetYeuYevYewxyzx{|}~}~}~}~}~}~}~}~    $turtle-1.5.24-99TsyArsau1KuZyBhZ9YirTurtle Turtle.ShellTurtle.Options Turtle.BytesTurtle.Prelude Turtle.Line Turtle.FormatTurtle.PatternTurtle.Internalprintf Data.MaybeJust Data.EitherRightTurtle.Tutorialbase Data.String fromString Control.MonadguardGHC.Base<>memptymappendmconcatjoin<*>pure*>IsString ApplicativeMonoidGHC.IO.Handle.TypesHandleControl.Monad.IO.ClassliftIOMonadIOmfilterunless replicateM_forever<=<>=>Control.ApplicativeoptionalGHC.IO.Exception ExitFailure ExitSuccessExitCode Data.Foldablemsum Data.Function& Data.Functorvoid<$>when<*liftA2manysome<|>empty Alternativemplusmzero MonadPlus#foldl-1.4.12-4ydcczW7oktIUNIUMBh6j2 Control.FoldlFoldFoldM text-1.2.3.2Data.Text.InternalText$managed-1.0.9-FnxOLSOLS4NHHwak5dVnS5Control.Monad.Managed runManagedwithmanagedManagedusing4optparse-applicative-0.17.0.0-5cjXDACcJfeEbNebAuZNUAOptions.Applicative.TypesParser#zlib-0.6.2.3-2uGcMnfBpxZKTtDyehJOQ4Codec.Compression.Zlib.Stream WindowBitsdefaultWindowBits-system-filepath-0.4.14-8Q4E12470rGGhV5jJ3O02gFilesystem.Path.InternalFilePath-system-fileio-0.3.16.4-G0ispiwZOFy1KpjjQmxZm7 Filesystem writeTextFile readTextFileFilesystem.Path.CurrentOS decodeString encodeStringfromTexttoTextFilesystem.PathsplitExtension dropExtension<.> hasExtension extensionsplitDirectoriescollapse stripPrefix commonPrefixrelativeabsolutebasenamedirnamefilenameparent directoryroot time-1.9.3 Data.Time.Clock.Internal.UTCTimeUTCTime(Data.Time.Clock.Internal.NominalDiffTimeNominalDiffTime unix-2.7.2.2System.Posix.Files.CommonisSocketisSymbolicLink isDirectory isRegularFile isNamedPipeisCharacterDevice isBlockDevice FileStatusLineNewlineForbidden lineToText textToLines linesToText textToLineunsafeTextToLine$fExceptionNewlineForbidden$fIsStringLine$fSemigroupLine$fEqLine $fOrdLine $fShowLine $fMonoidLine$fShowNewlineForbiddenFormat>>-%formateprintf makeFormatwduoxfegslfputcrepr$fIsStringFormat$fCategoryTYPEFormat HelpMessagegetHelpMessage DescriptiongetDescription CommandNamegetCommandName ShortNameArgName getArgNameoptions optionsExtswitchoptoptReadoptInt optInteger optDoubleoptTextoptLineoptPathargargReadargInt argInteger argDoubleargTextargLineargPath subcommandsubcommandGroup$fIsStringHelpMessage$fIsStringFooter$fIsStringHeader$fIsStringDescription$fIsStringCommandName$fIsStringArgNamePatternmatchanyChareofdotsatisfycharnotChartextasciiCIoneOfnoneOfspacespacesspaces1tabnewlinecrlfupperloweralphaNumletterdigithexDigitoctDigitdecimalsignedinvertonceprefixsuffixhasbeginsendscontainsstarplusselflesschoicecount lowerBounded upperBoundedboundedoptionbetweenskipwithinfixedsepBysepBy1charschars1$fIsStringPattern $fNumPattern$fMonoidPattern$fSemigroupPattern$fFunctorPattern$fApplicativePattern$fMonadPattern$fAlternativePattern$fMonadPlusPatternShell _foldShell FoldShellfoldIO_foldIO_Shell foldShellfoldreduceshviewselectfromIO$fIsStringShell $fNumShell $fMonoidShell$fSemigroupShell$fMonadFailShell$fMonadCatchShell$fMonadThrowShell$fMonadManagedShell$fMonadIOShell$fMonadPlusShell$fAlternativeShell $fMonadShell$fApplicativeShell$fFunctorShell WithHeaderHeaderRowSize Permissions _readable _writable _executable ShellFailedshellCommandLine shellExitCode ProcFailed procCommand procArguments procExitCodeTiB tebibytesGiB gibibytesMiB mebibytesKiB kibibytesTB terabytesGB gigabytesMB megabytesKB kilobytesBbytesprocshellprocsshells procStrict shellStrictprocStrictWithErrshellStrictWithErrsystem systemStrictsystemStrictWithErrinprocinshellstream streamWithErr inprocWithErrinshellWithErrechoerrreadline argumentsexportunsetneedenvcdpushdpwdhomereadlinkrealpathlslstreelsdepthlsifmvmkdirmktreecpsymlinkisNotSymbolicLinkcptreecptreeLrmrmdirrmtreetestfiletestdirtestpathtouchchmodgetmodsetmodcopymodreadable nonreadablewritable nonwritable executable nonexecutableooorooowoooxrworoxowxrwxtimehostnamewhichwhichAllsleepexitdie.&&..||. mktempdirmktemp mktempfileforkwaitstdininputinhandlestdoutoutput outhandleappendstderrstrictreadonly writeonly appendonlycatgrepgrepTextsed sedPrefix sedSuffix sedEntireonFilesinplace inplacePrefix inplaceSuffix inplaceEntireupdatefindfindtreecmincmaxyesnlpasteendlesslimit limitWhilecacheparallelcutdatedatefiledusz countChars countWords countLinesstatfileSize accessTimemodificationTimestatusChangeTimelstatheadersingleuniquniqOnuniqBynubnubOnsortsortOnsortBytoLines$fExceptionProcFailed$fExceptionShellFailed $fShowSize$fShowWithHeader$fEqSize $fOrdSize $fNumSize$fEqPermissions$fReadPermissions$fOrdPermissions$fShowPermissions$fShowShellFailed$fShowProcFailedcompress decompresstoUTF8fromUTF8<&> ignoreSIGPIPEGHC.ShowShowGHC.RealIntegralghc-prim GHC.TypesWordDoubleTrueFalseGHC.ReadReadIntinteger-wired-inGHC.Integer.TypeIntegerCharIOexceptions-0.10.4Control.Monad.Catch MonadCatch System.IOprint GHC.MaybeMaybeGHC.NumNumdirectory-1.3.6.0 System.Directory.Internal.Common searchableLeftNothing GHC.Classes&&||"async-2.2.4-4JG4UQZhHlOKvfwb7nDkNcControl.Concurrent.AsyncAsyncbytestring-0.10.10.0Data.ByteString.Internal ByteStringGHC.Errerrorflipfmap