summaryrefslogtreecommitdiff
path: root/CmdLine
diff options
context:
space:
mode:
authorGravatar Joey Hess <joeyh@joeyh.name>2015-07-11 20:43:45 -0400
committerGravatar Joey Hess <joeyh@joeyh.name>2015-07-11 20:43:45 -0400
commitd49e9f6a744c490cf4374039fde26c0eb57dc675 (patch)
tree8309f1255db293d410145573c0cd831015d6629c /CmdLine
parentdb0fd46eddd191632d849f425f5db5ab3eed3905 (diff)
converted ContentLocation, ExampleKey, LookupKey
Diffstat (limited to 'CmdLine')
-rw-r--r--CmdLine/Batch.hs35
-rw-r--r--CmdLine/GitAnnex.hs12
2 files changed, 30 insertions, 17 deletions
diff --git a/CmdLine/Batch.hs b/CmdLine/Batch.hs
index 24f942978..57823b67b 100644
--- a/CmdLine/Batch.hs
+++ b/CmdLine/Batch.hs
@@ -10,29 +10,42 @@ module CmdLine.Batch where
import Common.Annex
import Command
-batchOption :: Option
-batchOption = flagOption [] "batch" "enable batch mode"
-
data BatchMode = Batch | NoBatch
+
+batchOption :: Parser BatchMode
+batchOption = flag NoBatch Batch
+ ( long "batch"
+ <> help "enable batch mode"
+ )
+
type Batchable t = BatchMode -> t -> CommandStart
-- A Batchable command can run in batch mode, or not.
-- In batch mode, one line at a time is read, parsed, and a reply output to
-- stdout. In non batch mode, the command's parameters are parsed and
-- a reply output for each.
-batchable :: ((t -> CommandStart) -> CmdParams -> CommandSeek) -> Batchable t -> CmdParams -> CommandSeek
-batchable seeker starter params = ifM (getOptionFlag batchOption)
- ( batchloop
- , seeker (starter NoBatch) params
- )
+batchable :: (opts -> String -> Annex Bool) -> Parser opts -> CmdParamsDesc -> CommandParser
+batchable handler parser paramdesc = batchseeker <$> batchparser
where
- batchloop = do
+ batchparser = (,,)
+ <$> parser
+ <*> batchOption
+ <*> cmdParams paramdesc
+
+ batchseeker (opts, NoBatch, params) = mapM_ (go NoBatch opts) params
+ batchseeker (opts, Batch, _) = batchloop opts
+
+ batchloop opts = do
mp <- liftIO $ catchMaybeIO getLine
case mp of
Nothing -> return ()
Just p -> do
- seeker (starter Batch) [p]
- batchloop
+ go Batch opts p
+ batchloop opts
+
+ go batchmode opts p =
+ unlessM (handler opts p) $
+ batchBadInput batchmode
-- bad input is indicated by an empty line in batch mode. In non batch
-- mode, exit on bad input.
diff --git a/CmdLine/GitAnnex.hs b/CmdLine/GitAnnex.hs
index 74a831f8b..c569519e5 100644
--- a/CmdLine/GitAnnex.hs
+++ b/CmdLine/GitAnnex.hs
@@ -23,9 +23,9 @@ import qualified Command.Move
import qualified Command.Copy
import qualified Command.Get
import qualified Command.Fsck
---import qualified Command.LookupKey
---import qualified Command.ContentLocation
---import qualified Command.ExamineKey
+import qualified Command.LookupKey
+import qualified Command.ContentLocation
+import qualified Command.ExamineKey
import qualified Command.FromKey
import qualified Command.RegisterUrl
import qualified Command.SetKey
@@ -158,9 +158,9 @@ cmds =
, Command.Schedule.cmd
, Command.Ungroup.cmd
, Command.Vicfg.cmd
--- , Command.LookupKey.cmd
--- , Command.ContentLocation.cmd
--- , Command.ExamineKey.cmd
+ , Command.LookupKey.cmd
+ , Command.ContentLocation.cmd
+ , Command.ExamineKey.cmd
, Command.FromKey.cmd
, Command.RegisterUrl.cmd
, Command.SetKey.cmd