2014-03-26 04:10:30 +04:00
|
|
|
{-|
|
|
|
|
|
|
|
|
hledger's cmdargs modes parse command-line arguments to an
|
|
|
|
intermediate format, RawOpts (an association list), rather than a
|
|
|
|
fixed ADT like CliOpts. This allows the modes and flags to be reused
|
|
|
|
more easily by hledger commands/scripts in this and other packages.
|
|
|
|
|
|
|
|
-}
|
|
|
|
|
|
|
|
module Hledger.Data.RawOptions (
|
|
|
|
RawOpts,
|
|
|
|
setopt,
|
|
|
|
setboolopt,
|
|
|
|
inRawOpts,
|
|
|
|
boolopt,
|
|
|
|
stringopt,
|
|
|
|
maybestringopt,
|
|
|
|
listofstringopt,
|
|
|
|
intopt,
|
2018-09-07 20:12:13 +03:00
|
|
|
maybeintopt,
|
|
|
|
maybecharopt
|
2014-03-26 04:10:30 +04:00
|
|
|
)
|
|
|
|
where
|
|
|
|
|
|
|
|
import Data.Maybe
|
2016-07-29 18:57:10 +03:00
|
|
|
import qualified Data.Text as T
|
2014-03-26 04:10:30 +04:00
|
|
|
import Safe
|
|
|
|
|
|
|
|
import Hledger.Utils
|
|
|
|
|
|
|
|
|
|
|
|
-- | The result of running cmdargs: an association list of option names to string values.
|
|
|
|
type RawOpts = [(String,String)]
|
|
|
|
|
|
|
|
setopt :: String -> String -> RawOpts -> RawOpts
|
2016-07-29 18:57:10 +03:00
|
|
|
setopt name val = (++ [(name, quoteIfNeeded $ val)])
|
2014-03-26 04:10:30 +04:00
|
|
|
|
|
|
|
setboolopt :: String -> RawOpts -> RawOpts
|
|
|
|
setboolopt name = (++ [(name,"")])
|
|
|
|
|
|
|
|
-- | Is the named option present ?
|
|
|
|
inRawOpts :: String -> RawOpts -> Bool
|
|
|
|
inRawOpts name = isJust . lookup name
|
|
|
|
|
|
|
|
boolopt :: String -> RawOpts -> Bool
|
|
|
|
boolopt = inRawOpts
|
|
|
|
|
|
|
|
maybestringopt :: String -> RawOpts -> Maybe String
|
2019-02-14 16:14:52 +03:00
|
|
|
maybestringopt name = fmap (T.unpack . stripquotes . T.pack) . lookup name . reverse
|
2014-03-26 04:10:30 +04:00
|
|
|
|
|
|
|
stringopt :: String -> RawOpts -> String
|
|
|
|
stringopt name = fromMaybe "" . maybestringopt name
|
|
|
|
|
2018-09-07 20:12:13 +03:00
|
|
|
maybecharopt :: String -> RawOpts -> Maybe Char
|
|
|
|
maybecharopt name rawopts = lookup name rawopts >>= headMay
|
|
|
|
|
2014-03-26 04:10:30 +04:00
|
|
|
listofstringopt :: String -> RawOpts -> [String]
|
|
|
|
listofstringopt name rawopts = [v | (k,v) <- rawopts, k==name]
|
|
|
|
|
|
|
|
maybeintopt :: String -> RawOpts -> Maybe Int
|
|
|
|
maybeintopt name rawopts =
|
|
|
|
let ms = maybestringopt name rawopts in
|
|
|
|
case ms of Nothing -> Nothing
|
2017-03-29 18:00:30 +03:00
|
|
|
Just s -> Just $ readDef (usageError $ "could not parse "++name++" number: "++s) s
|
2014-03-26 04:10:30 +04:00
|
|
|
|
|
|
|
intopt :: String -> RawOpts -> Int
|
|
|
|
intopt name = fromMaybe 0 . maybeintopt name
|
|
|
|
|