git-annex/CmdLine/Option.hs

90 lines
2.4 KiB
Haskell
Raw Normal View History

2013-03-27 17:51:24 +00:00
{- common command-line options
-
- Copyright 2010-2011 Joey Hess <id@joeyh.name>
-
- Licensed under the GNU GPL version 3 or higher.
-}
2014-01-26 20:25:55 +00:00
module CmdLine.Option (
commonGlobalOptions,
2014-01-26 20:25:55 +00:00
flagOption,
fieldOption,
optionName,
optionParam,
ArgDescr(..),
OptDescr(..),
) where
import Options.Applicative
import System.Console.GetOpt
2011-10-05 20:02:51 +00:00
import Common.Annex
import CmdLine.Usage
import CmdLine.GlobalSetter
import qualified Annex
import Types.Messages
import Types.DeferredParse
-- Global options accepted by both git-annex and git-annex-shell sub-commands.
commonGlobalOptions :: [GlobalOption]
commonGlobalOptions =
[ globalFlag (setforce True)
( long "force"
<> help "allow actions that may lose annexed data"
<> hidden
)
, globalFlag (setfast True)
( long "fast" <> short 'F'
<> help "avoid slow operations"
<> hidden
)
, globalFlag (Annex.setOutput QuietOutput)
( long "quiet" <> short 'q'
<> help "avoid verbose output"
<> hidden
)
, globalFlag (Annex.setOutput NormalOutput)
( long "verbose" <> short 'v'
<> help "allow verbose output (default)"
<> hidden
)
, globalFlag setdebug
( long "debug" <> short 'd'
<> help "show debug messages"
<> hidden
)
, globalFlag unsetdebug
( long "no-debug"
<> help "don't show debug messages"
<> hidden
)
, globalSetter setforcebackend $ strOption
( long "backend" <> short 'b' <> metavar paramName
<> help "specify key-value backend to use"
<> hidden
)
]
where
setforce v = Annex.changeState $ \s -> s { Annex.force = v }
setfast v = Annex.changeState $ \s -> s { Annex.fast = v }
setforcebackend v = Annex.changeState $ \s -> s { Annex.forcebackend = Just v }
setdebug = Annex.changeGitConfig $ \c -> c { annexDebug = True }
unsetdebug = Annex.changeGitConfig $ \c -> c { annexDebug = False }
2012-01-06 14:14:37 +00:00
{- An option that sets a flag. -}
2014-01-26 20:25:55 +00:00
flagOption :: String -> String -> String -> Option
flagOption shortv opt description =
Option shortv [opt] (NoArg (Annex.setFlag opt)) description
{- An option that sets a field. -}
2014-01-26 20:25:55 +00:00
fieldOption :: String -> String -> String -> String -> Option
fieldOption shortv opt paramdesc description =
Option shortv [opt] (ReqArg (Annex.setField opt) paramdesc) description
2012-01-06 14:14:37 +00:00
{- The flag or field name used for an option. -}
2014-01-26 20:25:55 +00:00
optionName :: Option -> String
optionName (Option _ o _ _) = Prelude.head o
optionParam :: Option -> String
optionParam o = "--" ++ optionName o