2012-05-09 19:16:01 +04:00
|
|
|
name: optparse-applicative
|
2012-09-04 20:28:43 +04:00
|
|
|
version: 0.4.1
|
2012-05-12 21:54:53 +04:00
|
|
|
synopsis: Utilities and combinators for parsing command line options
|
|
|
|
description:
|
|
|
|
Here is a simple example of an applicative option parser:
|
|
|
|
.
|
|
|
|
@
|
|
|
|
data Sample = Sample
|
|
|
|
  { hello :: String
|
|
|
|
  , quiet :: Bool }
|
|
|
|
.
|
|
|
|
sample :: Parser Sample
|
|
|
|
sample = Sample
|
|
|
|
  \<$\> strOption
|
|
|
|
  ( long \"hello\"
|
|
|
|
  & metavar \"TARGET\"
|
|
|
|
  & help \"Target for the greeting\" )
|
|
|
|
  \<*\> switch
|
|
|
|
  ( long \"quiet\"
|
|
|
|
  & help \"Whether to be quiet\" )
|
|
|
|
@
|
|
|
|
.
|
|
|
|
The parser is built using applicative style starting from a set of basic
|
|
|
|
combinators. In this example, @hello@ is defined as an 'option' with a
|
|
|
|
@String@ argument, while @quiet@ is a boolean 'flag' (called 'switch').
|
|
|
|
.
|
|
|
|
A parser can be used like this:
|
|
|
|
.
|
|
|
|
@
|
|
|
|
greet :: Sample -> IO ()
|
2012-06-12 01:42:45 +04:00
|
|
|
greet (Sample h False) = putStrLn $ \"Hello, \" ++ h
|
2012-05-12 21:54:53 +04:00
|
|
|
greet _ = return ()
|
|
|
|
.
|
|
|
|
main :: IO ()
|
|
|
|
main = execParser opts \>\>= greet
|
|
|
|
  where
|
2012-06-09 04:02:47 +04:00
|
|
|
  opts = info (helper \<*\> sample)
|
|
|
|
  ( fullDesc
|
|
|
|
  & progDesc \"Print a greeting for TARGET\"
|
|
|
|
  & header \"hello - a test for optparse-applicative\" )
|
2012-05-12 21:54:53 +04:00
|
|
|
@
|
|
|
|
.
|
|
|
|
The @greet@ function is the entry point of the program, while @opts@ is a
|
|
|
|
complete description of the program, used when generating a help text. The
|
|
|
|
'helper' combinator takes any parser, and adds a @help@ option to it (which
|
|
|
|
always fails).
|
|
|
|
.
|
|
|
|
The @hello@ option in this example is mandatory (since it doesn't have a
|
|
|
|
default value), so running the program without any argument will display a
|
|
|
|
help text:
|
|
|
|
.
|
|
|
|
>hello - a test for optparse-applicative
|
|
|
|
>
|
|
|
|
>Usage: hello --hello TARGET [--quiet]
|
|
|
|
> Print a greeting for TARGET
|
|
|
|
>
|
2012-07-30 21:46:43 +04:00
|
|
|
>Available options:
|
2012-05-12 21:54:53 +04:00
|
|
|
> -h,--help Show this help text
|
|
|
|
> --hello TARGET Target for the greeting
|
|
|
|
> --quiet Whether to be quiet
|
|
|
|
.
|
|
|
|
containing a short usage summary, and a detailed list of options with
|
|
|
|
descriptions.
|
2012-05-09 19:16:01 +04:00
|
|
|
license: BSD3
|
|
|
|
license-file: LICENSE
|
|
|
|
author: Paolo Capriotti
|
|
|
|
maintainer: p.capriotti@gmail.com
|
|
|
|
copyright: (c) 2012 Paolo Capriotti <p.capriotti@gmail.com>
|
|
|
|
category: System
|
|
|
|
build-type: Simple
|
|
|
|
cabal-version: >= 1.8
|
2012-05-12 21:54:53 +04:00
|
|
|
extra-source-files: README.md
|
2012-07-30 22:37:00 +04:00
|
|
|
homepage: https://github.com/pcapriotti/optparse-applicative
|
|
|
|
bug-reports: https://github.com/pcapriotti/optparse-applicative/issues
|
2012-05-09 19:16:01 +04:00
|
|
|
|
|
|
|
library
|
|
|
|
exposed-modules: Options.Applicative,
|
2012-07-08 02:23:56 +04:00
|
|
|
Options.Applicative.Arrows,
|
2012-08-01 00:11:16 +04:00
|
|
|
Options.Applicative.BashCompletion,
|
2012-05-09 19:16:01 +04:00
|
|
|
Options.Applicative.Builder,
|
2012-09-23 16:56:19 +04:00
|
|
|
Options.Applicative.Builder.Arguments,
|
2012-08-03 01:13:58 +04:00
|
|
|
Options.Applicative.Builder.Completer,
|
2012-09-23 16:56:19 +04:00
|
|
|
Options.Applicative.Builder.Internal,
|
2012-08-01 01:28:32 +04:00
|
|
|
Options.Applicative.Common,
|
2012-05-09 19:46:26 +04:00
|
|
|
Options.Applicative.Extra,
|
2012-08-01 01:28:32 +04:00
|
|
|
Options.Applicative.Help,
|
|
|
|
Options.Applicative.Types,
|
|
|
|
Options.Applicative.Utils
|
|
|
|
other-modules: Options.Applicative.Internal
|
2012-06-09 03:40:00 +04:00
|
|
|
build-depends: base == 4.*,
|
2012-08-02 21:13:50 +04:00
|
|
|
transformers >= 0.2 && < 0.4,
|
2012-08-02 23:19:14 +04:00
|
|
|
process == 1.1.*
|
2012-05-10 00:51:49 +04:00
|
|
|
test-suite tests
|
|
|
|
type: exitcode-stdio-1.0
|
|
|
|
hs-source-dirs: tests
|
|
|
|
main-is: Tests.hs
|
2012-06-09 03:40:00 +04:00
|
|
|
build-depends: base == 4.*,
|
2012-05-10 00:51:49 +04:00
|
|
|
HUnit == 1.2.*,
|
2012-08-01 01:09:49 +04:00
|
|
|
optparse-applicative,
|
2012-05-10 00:51:49 +04:00
|
|
|
test-framework == 0.6.*,
|
|
|
|
test-framework-hunit == 0.2.*,
|
|
|
|
test-framework-th-prime == 0.0.*
|