summaryrefslogtreecommitdiff
path: root/Command
diff options
context:
space:
mode:
authorGravatar Joey Hess <joeyh@joeyh.name>2015-07-08 12:33:27 -0400
committerGravatar Joey Hess <joeyh@joeyh.name>2015-07-08 13:36:25 -0400
commite73914b7950ce9d26a3882472c7ab27260ff87f9 (patch)
tree33d4a11106a005eadfe317505ea2786e83cf5bc8 /Command
parent8ce422d8ab390e105d70f049c30d81c14d3b64b4 (diff)
started converting to use optparse-applicative
This is a work in progress. It compiles and is able to do basic command dispatch, including git autocorrection, while using optparse-applicative for the core commandline parsing. * Many commands are temporarily disabled before conversion. * Options are not wired in yet. * cmdnorepo actions don't work yet. Also, removed the [Command] list, which was only used in one place.
Diffstat (limited to 'Command')
-rw-r--r--Command/Add.hs9
-rw-r--r--Command/AddUnused.hs6
-rw-r--r--Command/AddUrl.hs6
-rw-r--r--Command/Assistant.hs6
-rw-r--r--Command/CheckPresentKey.hs6
-rw-r--r--Command/Commit.hs9
-rw-r--r--Command/ConfigList.hs9
-rw-r--r--Command/ContentLocation.hs6
-rw-r--r--Command/Copy.hs6
-rw-r--r--Command/Dead.hs6
-rw-r--r--Command/Describe.hs6
-rw-r--r--Command/DiffDriver.hs6
-rw-r--r--Command/Direct.hs6
-rw-r--r--Command/Drop.hs6
-rw-r--r--Command/DropKey.hs9
-rw-r--r--Command/DropUnused.hs6
-rw-r--r--Command/EnableRemote.hs6
-rw-r--r--Command/ExamineKey.hs6
-rw-r--r--Command/Expire.hs6
-rw-r--r--Command/Find.hs6
-rw-r--r--Command/FindRef.hs6
-rw-r--r--Command/Fix.hs11
-rw-r--r--Command/Forget.hs6
-rw-r--r--Command/FromKey.hs6
-rw-r--r--Command/Fsck.hs6
-rw-r--r--Command/FuzzTest.hs6
-rw-r--r--Command/GCryptSetup.hs11
-rw-r--r--Command/Get.hs6
-rw-r--r--Command/Group.hs6
-rw-r--r--Command/GroupWanted.hs6
-rw-r--r--Command/Help.hs6
-rw-r--r--Command/Import.hs6
-rw-r--r--Command/ImportFeed.hs6
-rw-r--r--Command/InAnnex.hs9
-rw-r--r--Command/Indirect.hs6
-rw-r--r--Command/Info.hs6
-rw-r--r--Command/Init.hs6
-rw-r--r--Command/InitRemote.hs6
-rw-r--r--Command/List.hs6
-rw-r--r--Command/Lock.hs6
-rw-r--r--Command/Log.hs6
-rw-r--r--Command/LookupKey.hs6
-rw-r--r--Command/Map.hs6
-rw-r--r--Command/Merge.hs6
-rw-r--r--Command/MetaData.hs6
-rw-r--r--Command/Migrate.hs6
-rw-r--r--Command/Mirror.hs6
-rw-r--r--Command/Move.hs6
-rw-r--r--Command/NotifyChanges.hs9
-rw-r--r--Command/NumCopies.hs6
-rw-r--r--Command/PreCommit.hs9
-rw-r--r--Command/Proxy.hs6
-rw-r--r--Command/ReKey.hs6
-rw-r--r--Command/ReadPresentKey.hs6
-rw-r--r--Command/RecvKey.hs9
-rw-r--r--Command/RegisterUrl.hs6
-rw-r--r--Command/Reinit.hs5
-rw-r--r--Command/Reinject.hs4
-rw-r--r--Command/RemoteDaemon.hs6
-rw-r--r--Command/Repair.hs6
-rw-r--r--Command/Required.hs2
-rw-r--r--Command/ResolveMerge.hs6
-rw-r--r--Command/RmUrl.hs6
-rw-r--r--Command/Schedule.hs6
-rw-r--r--Command/Semitrust.hs6
-rw-r--r--Command/SendKey.hs9
-rw-r--r--Command/SetKey.hs6
-rw-r--r--Command/SetPresentKey.hs6
-rw-r--r--Command/Status.hs6
-rw-r--r--Command/Sync.hs6
-rw-r--r--Command/Test.hs6
-rw-r--r--Command/TestRemote.hs6
-rw-r--r--Command/TransferInfo.hs9
-rw-r--r--Command/TransferKey.hs6
-rw-r--r--Command/TransferKeys.hs6
-rw-r--r--Command/Trust.hs6
-rw-r--r--Command/Unannex.hs11
-rw-r--r--Command/Undo.hs6
-rw-r--r--Command/Ungroup.hs6
-rw-r--r--Command/Uninit.hs9
-rw-r--r--Command/Unlock.hs17
-rw-r--r--Command/Untrust.hs6
-rw-r--r--Command/Unused.hs11
-rw-r--r--Command/Upgrade.hs6
-rw-r--r--Command/VAdd.hs6
-rw-r--r--Command/VCycle.hs6
-rw-r--r--Command/VFilter.hs6
-rw-r--r--Command/VPop.hs6
-rw-r--r--Command/Version.hs6
-rw-r--r--Command/Vicfg.hs6
-rw-r--r--Command/View.hs6
-rw-r--r--Command/Wanted.hs6
-rw-r--r--Command/Watch.hs6
-rw-r--r--Command/WebApp.hs6
-rw-r--r--Command/Whereis.hs6
-rw-r--r--Command/XMPPGit.hs6
96 files changed, 325 insertions, 308 deletions
diff --git a/Command/Add.hs b/Command/Add.hs
index 5f6f06cdb..689f2c6a5 100644
--- a/Command/Add.hs
+++ b/Command/Add.hs
@@ -34,9 +34,10 @@ import Utility.Tmp
import Control.Exception (IOException)
-cmd :: [Command]
-cmd = [notBareRepo $ withOptions addOptions $
- command "add" paramPaths seek SectionCommon "add files to annex"]
+cmd :: Command
+cmd = notBareRepo $ withOptions addOptions $
+ command "add" paramPaths SectionCommon "add files to annex"
+ (commandParser seek)
addOptions :: [Option]
addOptions = includeDotFilesOption : fileMatchingOptions
@@ -47,7 +48,7 @@ includeDotFilesOption = flagOption [] "include-dotfiles" "don't skip dotfiles"
{- Add acts on both files not checked into git yet, and unlocked files.
-
- In direct mode, it acts on any files that have changed. -}
-seek :: CommandSeek
+seek :: CmdParams -> CommandSeek
seek ps = do
matcher <- largeFilesMatcher
let go a = flip a ps $ \file -> ifM (checkFileMatcher matcher file <||> Annex.getState Annex.force)
diff --git a/Command/AddUnused.hs b/Command/AddUnused.hs
index 4aab8d017..a0e9ccba6 100644
--- a/Command/AddUnused.hs
+++ b/Command/AddUnused.hs
@@ -14,9 +14,9 @@ import qualified Command.Add
import Command.Unused (withUnusedMaps, UnusedMaps(..), startUnused)
import Types.Key
-cmd :: [Command]
-cmd = [notDirect $ command "addunused" (paramRepeating paramNumRange)
- seek SectionMaintenance "add back unused files"]
+cmd :: Command
+cmd = notDirect $ command "addunused" (paramRepeating paramNumRange)
+ seek SectionMaintenance "add back unused files"
seek :: CommandSeek
seek = withUnusedMaps start
diff --git a/Command/AddUrl.hs b/Command/AddUrl.hs
index fda2a99e0..f009ff388 100644
--- a/Command/AddUrl.hs
+++ b/Command/AddUrl.hs
@@ -37,10 +37,10 @@ import Annex.Quvi
import qualified Utility.Quvi as Quvi
#endif
-cmd :: [Command]
-cmd = [notBareRepo $ withOptions [fileOption, pathdepthOption, relaxedOption, rawOption] $
+cmd :: Command
+cmd = notBareRepo $ withOptions [fileOption, pathdepthOption, relaxedOption, rawOption] $
command "addurl" (paramRepeating paramUrl) seek
- SectionCommon "add urls to annex"]
+ SectionCommon "add urls to annex"
fileOption :: Option
fileOption = fieldOption [] "file" paramFile "specify what file the url is added to"
diff --git a/Command/Assistant.hs b/Command/Assistant.hs
index 8a916aa55..d405bc8b3 100644
--- a/Command/Assistant.hs
+++ b/Command/Assistant.hs
@@ -19,10 +19,10 @@ import Assistant.Install
import System.Environment
-cmd :: [Command]
-cmd = [noRepo checkNoRepoOpts $ dontCheck repoExists $ withOptions options $
+cmd :: Command
+cmd = noRepo checkNoRepoOpts $ dontCheck repoExists $ withOptions options $
notBareRepo $ command "assistant" paramNothing seek SectionCommon
- "automatically sync changes"]
+ "automatically sync changes"
options :: [Option]
options =
diff --git a/Command/CheckPresentKey.hs b/Command/CheckPresentKey.hs
index ad61ba3c0..e212a2da8 100644
--- a/Command/CheckPresentKey.hs
+++ b/Command/CheckPresentKey.hs
@@ -14,9 +14,9 @@ import qualified Remote
import Annex
import Types.Messages
-cmd :: [Command]
-cmd = [noCommit $ command "checkpresentkey" (paramPair paramKey paramRemote) seek
- SectionPlumbing "check if key is present in remote"]
+cmd :: Command
+cmd = noCommit $ command "checkpresentkey" (paramPair paramKey paramRemote) seek
+ SectionPlumbing "check if key is present in remote"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/Commit.hs b/Command/Commit.hs
index 73f9e2d5e..b94182a06 100644
--- a/Command/Commit.hs
+++ b/Command/Commit.hs
@@ -12,11 +12,12 @@ import Command
import qualified Annex.Branch
import qualified Git
-cmd :: [Command]
-cmd = [command "commit" paramNothing seek
- SectionPlumbing "commits any staged changes to the git-annex branch"]
+cmd :: Command
+cmd = command "commit" paramNothing
+ SectionPlumbing "commits any staged changes to the git-annex branch"
+ (commandParser seek)
-seek :: CommandSeek
+seek :: CmdParams -> CommandSeek
seek = withNothing start
start :: CommandStart
diff --git a/Command/ConfigList.hs b/Command/ConfigList.hs
index 33b348b07..78c6d8d24 100644
--- a/Command/ConfigList.hs
+++ b/Command/ConfigList.hs
@@ -15,11 +15,12 @@ import qualified Annex.Branch
import qualified Git.Config
import Remote.GCrypt (coreGCryptId)
-cmd :: [Command]
-cmd = [noCommit $ command "configlist" paramNothing seek
- SectionPlumbing "outputs relevant git configuration"]
+cmd :: Command
+cmd = noCommit $ command "configlist" paramNothing
+ SectionPlumbing "outputs relevant git configuration"
+ (commandParser seek)
-seek :: CommandSeek
+seek :: CmdParams -> CommandSeek
seek = withNothing start
start :: CommandStart
diff --git a/Command/ContentLocation.hs b/Command/ContentLocation.hs
index 10879f5b1..be781b5e2 100644
--- a/Command/ContentLocation.hs
+++ b/Command/ContentLocation.hs
@@ -12,10 +12,10 @@ import Command
import CmdLine.Batch
import Annex.Content
-cmd :: [Command]
-cmd = [withOptions [batchOption] $ noCommit $ noMessages $
+cmd :: Command
+cmd = withOptions [batchOption] $ noCommit $ noMessages $
command "contentlocation" (paramRepeating paramKey) seek
- SectionPlumbing "looks up content for a key"]
+ SectionPlumbing "looks up content for a key"
seek :: CommandSeek
seek = batchable withKeys start
diff --git a/Command/Copy.hs b/Command/Copy.hs
index 5cfdabb4e..ab4d8e25e 100644
--- a/Command/Copy.hs
+++ b/Command/Copy.hs
@@ -14,9 +14,9 @@ import qualified Remote
import Annex.Wanted
import Annex.NumCopies
-cmd :: [Command]
-cmd = [withOptions copyOptions $ command "copy" paramPaths seek
- SectionCommon "copy content of files to/from another repository"]
+cmd :: Command
+cmd = withOptions copyOptions $ command "copy" paramPaths seek
+ SectionCommon "copy content of files to/from another repository"
copyOptions :: [Option]
copyOptions = Command.Move.moveOptions ++ [autoOption]
diff --git a/Command/Dead.hs b/Command/Dead.hs
index 7e62b6db0..75efd0dd5 100644
--- a/Command/Dead.hs
+++ b/Command/Dead.hs
@@ -16,10 +16,10 @@ import Command.Trust (trustCommand)
import Logs.Location
import Remote (keyLocations)
-cmd :: [Command]
-cmd = [withOptions [keyOption] $
+cmd :: Command
+cmd = withOptions [keyOption] $
command "dead" (paramRepeating paramRemote) seek
- SectionSetup "hide a lost repository or key"]
+ SectionSetup "hide a lost repository or key"
seek :: CommandSeek
seek ps = maybe (trustCommand "dead" DeadTrusted ps) (flip seekKey ps)
diff --git a/Command/Describe.hs b/Command/Describe.hs
index 56a73334d..6ff67f112 100644
--- a/Command/Describe.hs
+++ b/Command/Describe.hs
@@ -12,9 +12,9 @@ import Command
import qualified Remote
import Logs.UUID
-cmd :: [Command]
-cmd = [command "describe" (paramPair paramRemote paramDesc) seek
- SectionSetup "change description of a repository"]
+cmd :: Command
+cmd = command "describe" (paramPair paramRemote paramDesc) seek
+ SectionSetup "change description of a repository"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/DiffDriver.hs b/Command/DiffDriver.hs
index f6ef77ecd..c93bec525 100644
--- a/Command/DiffDriver.hs
+++ b/Command/DiffDriver.hs
@@ -13,10 +13,10 @@ import Annex.Content
import Annex.Link
import Git.Types
-cmd :: [Command]
-cmd = [dontCheck repoExists $
+cmd :: Command
+cmd = dontCheck repoExists $
command "diffdriver" ("[-- cmd --]") seek
- SectionPlumbing "external git diff driver shim"]
+ SectionPlumbing "external git diff driver shim"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/Direct.hs b/Command/Direct.hs
index 1a6b2cb05..3eda794a0 100644
--- a/Command/Direct.hs
+++ b/Command/Direct.hs
@@ -15,10 +15,10 @@ import qualified Git.Branch
import Config
import Annex.Direct
-cmd :: [Command]
-cmd = [notBareRepo $ noDaemonRunning $
+cmd :: Command
+cmd = notBareRepo $ noDaemonRunning $
command "direct" paramNothing seek
- SectionSetup "switch repository to direct mode"]
+ SectionSetup "switch repository to direct mode"
seek :: CommandSeek
seek = withNothing start
diff --git a/Command/Drop.hs b/Command/Drop.hs
index 698dd7bad..496d5c55c 100644
--- a/Command/Drop.hs
+++ b/Command/Drop.hs
@@ -22,9 +22,9 @@ import Annex.Notification
import qualified Data.Set as S
-cmd :: [Command]
-cmd = [withOptions (dropOptions) $ command "drop" paramPaths seek
- SectionCommon "indicate content of files not currently wanted"]
+cmd :: Command
+cmd = withOptions (dropOptions) $ command "drop" paramPaths seek
+ SectionCommon "indicate content of files not currently wanted"
dropOptions :: [Option]
dropOptions = dropFromOption : annexedMatchingOptions ++ [autoOption] ++ keyOptions
diff --git a/Command/DropKey.hs b/Command/DropKey.hs
index 890a79466..09366c262 100644
--- a/Command/DropKey.hs
+++ b/Command/DropKey.hs
@@ -13,11 +13,12 @@ import qualified Annex
import Logs.Location
import Annex.Content
-cmd :: [Command]
-cmd = [noCommit $ command "dropkey" (paramRepeating paramKey) seek
- SectionPlumbing "drops annexed content for specified keys"]
+cmd :: Command
+cmd = noCommit $ command "dropkey" (paramRepeating paramKey)
+ SectionPlumbing "drops annexed content for specified keys"
+ (commandParser seek)
-seek :: CommandSeek
+seek :: CmdParams -> CommandSeek
seek = withKeys start
start :: Key -> CommandStart
diff --git a/Command/DropUnused.hs b/Command/DropUnused.hs
index d441a4bd2..99e1e063d 100644
--- a/Command/DropUnused.hs
+++ b/Command/DropUnused.hs
@@ -16,10 +16,10 @@ import qualified Git
import Command.Unused (withUnusedMaps, UnusedMaps(..), startUnused)
import Annex.NumCopies
-cmd :: [Command]
-cmd = [withOptions [Command.Drop.dropFromOption] $
+cmd :: Command
+cmd = withOptions [Command.Drop.dropFromOption] $
command "dropunused" (paramRepeating paramNumRange)
- seek SectionMaintenance "drop unused file content"]
+ seek SectionMaintenance "drop unused file content"
seek :: CommandSeek
seek ps = do
diff --git a/Command/EnableRemote.hs b/Command/EnableRemote.hs
index db3ec2b37..ccf6d9aab 100644
--- a/Command/EnableRemote.hs
+++ b/Command/EnableRemote.hs
@@ -15,10 +15,10 @@ import qualified Command.InitRemote as InitRemote
import qualified Data.Map as M
-cmd :: [Command]
-cmd = [command "enableremote"
+cmd :: Command
+cmd = command "enableremote"
(paramPair paramName $ paramOptional $ paramRepeating paramKeyValue)
- seek SectionSetup "enables use of an existing special remote"]
+ seek SectionSetup "enables use of an existing special remote"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/ExamineKey.hs b/Command/ExamineKey.hs
index 05db9817a..5ece3a99a 100644
--- a/Command/ExamineKey.hs
+++ b/Command/ExamineKey.hs
@@ -14,10 +14,10 @@ import qualified Utility.Format
import Command.Find (formatOption, getFormat, showFormatted, keyVars)
import Types.Key
-cmd :: [Command]
-cmd = [noCommit $ noMessages $ withOptions [formatOption, jsonOption, batchOption] $
+cmd :: Command
+cmd = noCommit $ noMessages $ withOptions [formatOption, jsonOption, batchOption] $
command "examinekey" (paramRepeating paramKey) seek
- SectionPlumbing "prints information from a key"]
+ SectionPlumbing "prints information from a key"
seek :: CommandSeek
seek ps = do
diff --git a/Command/Expire.hs b/Command/Expire.hs
index f4d1a06e3..44bdd113f 100644
--- a/Command/Expire.hs
+++ b/Command/Expire.hs
@@ -20,9 +20,9 @@ import Utility.HumanTime
import Data.Time.Clock.POSIX
import qualified Data.Map as M
-cmd :: [Command]
-cmd = [withOptions [activityOption, noActOption] $ command "expire" paramExpire seek
- SectionMaintenance "expire inactive repositories"]
+cmd :: Command
+cmd = withOptions [activityOption, noActOption] $ command "expire" paramExpire seek
+ SectionMaintenance "expire inactive repositories"
paramExpire :: String
paramExpire = (paramRepeating $ paramOptional paramRemote ++ ":" ++ paramTime)
diff --git a/Command/Find.hs b/Command/Find.hs
index 236824643..d0bb165c3 100644
--- a/Command/Find.hs
+++ b/Command/Find.hs
@@ -19,9 +19,9 @@ import qualified Utility.Format
import Utility.DataUnits
import Types.Key
-cmd :: [Command]
-cmd = [withOptions annexedMatchingOptions $ mkCommand $
- command "find" paramPaths seek SectionQuery "lists available files"]
+cmd :: Command
+cmd = withOptions annexedMatchingOptions $ mkCommand $
+ command "find" paramPaths seek SectionQuery "lists available files"
mkCommand :: Command -> Command
mkCommand = noCommit . noMessages . withOptions [formatOption, print0Option, jsonOption]
diff --git a/Command/FindRef.hs b/Command/FindRef.hs
index e7f7eae6d..3f09cd6b3 100644
--- a/Command/FindRef.hs
+++ b/Command/FindRef.hs
@@ -10,10 +10,10 @@ module Command.FindRef where
import Command
import qualified Command.Find as Find
-cmd :: [Command]
-cmd = [withOptions nonWorkTreeMatchingOptions $ Find.mkCommand $
+cmd :: Command
+cmd = withOptions nonWorkTreeMatchingOptions $ Find.mkCommand $
command "findref" paramRef seek SectionPlumbing
- "lists files in a git ref"]
+ "lists files in a git ref"
seek :: CommandSeek
seek refs = do
diff --git a/Command/Fix.hs b/Command/Fix.hs
index c4e5e52ee..6a27878e3 100644
--- a/Command/Fix.hs
+++ b/Command/Fix.hs
@@ -18,12 +18,13 @@ import Utility.Touch
#endif
#endif
-cmd :: [Command]
-cmd = [notDirect $ noCommit $ withOptions annexedMatchingOptions $
- command "fix" paramPaths seek
- SectionMaintenance "fix up symlinks to point to annexed content"]
+cmd :: Command
+cmd = notDirect $ noCommit $ withOptions annexedMatchingOptions $
+ command "fix" paramPaths
+ SectionMaintenance "fix up symlinks to point to annexed content"
+ (commandParser seek)
-seek :: CommandSeek
+seek :: CmdParams -> CommandSeek
seek = withFilesInGit $ whenAnnexed start
{- Fixes the symlink to an annexed file. -}
diff --git a/Command/Forget.hs b/Command/Forget.hs
index 94a1fb421..370dc8b1e 100644
--- a/Command/Forget.hs
+++ b/Command/Forget.hs
@@ -15,9 +15,9 @@ import qualified Annex
import Data.Time.Clock.POSIX
-cmd :: [Command]
-cmd = [withOptions forgetOptions $ command "forget" paramNothing seek
- SectionMaintenance "prune git-annex branch history"]
+cmd :: Command
+cmd = withOptions forgetOptions $ command "forget" paramNothing seek
+ SectionMaintenance "prune git-annex branch history"
forgetOptions :: [Option]
forgetOptions = [dropDeadOption]
diff --git a/Command/FromKey.hs b/Command/FromKey.hs
index 51389b770..78ebb6268 100644
--- a/Command/FromKey.hs
+++ b/Command/FromKey.hs
@@ -19,10 +19,10 @@ import qualified Backend.URL
import Network.URI
-cmd :: [Command]
-cmd = [notDirect $ notBareRepo $
+cmd :: Command
+cmd = notDirect $ notBareRepo $
command "fromkey" (paramPair paramKey paramPath) seek
- SectionPlumbing "adds a file using a specific key"]
+ SectionPlumbing "adds a file using a specific key"
seek :: CommandSeek
seek ps = do
diff --git a/Command/Fsck.hs b/Command/Fsck.hs
index 8988100b8..177db6498 100644
--- a/Command/Fsck.hs
+++ b/Command/Fsck.hs
@@ -40,9 +40,9 @@ import qualified Database.Fsck as FsckDb
import Data.Time.Clock.POSIX
import System.Posix.Types (EpochTime)
-cmd :: [Command]
-cmd = [withOptions fsckOptions $ command "fsck" paramPaths seek
- SectionMaintenance "check for problems"]
+cmd :: Command
+cmd = withOptions fsckOptions $ command "fsck" paramPaths seek
+ SectionMaintenance "check for problems"
fsckFromOption :: Option
fsckFromOption = fieldOption ['f'] "from" paramRemote "check remote"
diff --git a/Command/FuzzTest.hs b/Command/FuzzTest.hs
index d6c9e1ac1..bc8cc1161 100644
--- a/Command/FuzzTest.hs
+++ b/Command/FuzzTest.hs
@@ -20,9 +20,9 @@ import System.Random (getStdRandom, random, randomR)
import Test.QuickCheck
import Control.Concurrent
-cmd :: [Command]
-cmd = [ notBareRepo $ command "fuzztest" paramNothing seek SectionTesting
- "generates fuzz test files"]
+cmd :: Command
+cmd = notBareRepo $ command "fuzztest" paramNothing seek SectionTesting
+ "generates fuzz test files"
seek :: CommandSeek
seek = withNothing start
diff --git a/Command/GCryptSetup.hs b/Command/GCryptSetup.hs
index 7a7f8ae50..e267aaf67 100644
--- a/Command/GCryptSetup.hs
+++ b/Command/GCryptSetup.hs
@@ -13,12 +13,13 @@ import Annex.UUID
import qualified Remote.GCrypt
import qualified Git
-cmd :: [Command]
-cmd = [dontCheck repoExists $ noCommit $
- command "gcryptsetup" paramValue seek
- SectionPlumbing "sets up gcrypt repository"]
+cmd :: Command
+cmd = dontCheck repoExists $ noCommit $
+ command "gcryptsetup" paramValue
+ SectionPlumbing "sets up gcrypt repository"
+ (commandParser seek)
-seek :: CommandSeek
+seek :: CmdParams -> CommandSeek
seek = withStrings start
start :: String -> CommandStart
diff --git a/Command/Get.hs b/Command/Get.hs
index d39b3890f..f54e88b7a 100644
--- a/Command/Get.hs
+++ b/Command/Get.hs
@@ -16,9 +16,9 @@ import Annex.NumCopies
import Annex.Wanted
import qualified Command.Move
-cmd :: [Command]
-cmd = [withOptions getOptions $ command "get" paramPaths seek
- SectionCommon "make content of annexed files available"]
+cmd :: Command
+cmd = withOptions getOptions $ command "get" paramPaths seek
+ SectionCommon "make content of annexed files available"
getOptions :: [Option]
getOptions = fromOption : autoOption : jobsOption : annexedMatchingOptions
diff --git a/Command/Group.hs b/Command/Group.hs
index 820f6ab17..839d21a4c 100644
--- a/Command/Group.hs
+++ b/Command/Group.hs
@@ -15,9 +15,9 @@ import Types.Group
import qualified Data.Set as S
-cmd :: [Command]
-cmd = [command "group" (paramPair paramRemote paramDesc) seek
- SectionSetup "add a repository to a group"]
+cmd :: Command
+cmd = command "group" (paramPair paramRemote paramDesc) seek
+ SectionSetup "add a repository to a group"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/GroupWanted.hs b/Command/GroupWanted.hs
index 5cdf785d7..f58544f6f 100644
--- a/Command/GroupWanted.hs
+++ b/Command/GroupWanted.hs
@@ -12,9 +12,9 @@ import Command
import Logs.PreferredContent
import Command.Wanted (performGet, performSet)
-cmd :: [Command]
-cmd = [command "groupwanted" (paramPair paramGroup (paramOptional paramExpression)) seek
- SectionSetup "get or set groupwanted expression"]
+cmd :: Command
+cmd = command "groupwanted" (paramPair paramGroup (paramOptional paramExpression)) seek
+ SectionSetup "get or set groupwanted expression"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/Help.hs b/Command/Help.hs
index 2af39ac9a..073ab2b36 100644
--- a/Command/Help.hs
+++ b/Command/Help.hs
@@ -21,9 +21,9 @@ import qualified Command.Fsck
import System.Console.GetOpt
-cmd :: [Command]
-cmd = [noCommit $ noRepo startNoRepo $ dontCheck repoExists $
- command "help" (paramOptional "COMMAND") seek SectionCommon "display help"]
+cmd :: Command
+cmd = noCommit $ noRepo startNoRepo $ dontCheck repoExists $
+ command "help" (paramOptional "COMMAND") seek SectionCommon "display help"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/Import.hs b/Command/Import.hs
index acf3bc01f..6bc330fca 100644
--- a/Command/Import.hs
+++ b/Command/Import.hs
@@ -22,9 +22,9 @@ import Annex.NumCopies
import Types.TrustLevel
import Logs.Trust
-cmd :: [Command]
-cmd = [withOptions opts $ notBareRepo $ command "import" paramPaths seek
- SectionCommon "move and add files from outside git working copy"]
+cmd :: Command
+cmd = withOptions opts $ notBareRepo $ command "import" paramPaths seek
+ SectionCommon "move and add files from outside git working copy"
opts :: [Option]
opts = duplicateModeOptions ++ fileMatchingOptions
diff --git a/Command/ImportFeed.hs b/Command/ImportFeed.hs
index 4bc3f52f4..4be84375c 100644
--- a/Command/ImportFeed.hs
+++ b/Command/ImportFeed.hs
@@ -43,10 +43,10 @@ import Types.MetaData
import Logs.MetaData
import Annex.MetaData
-cmd :: [Command]
-cmd = [notBareRepo $ withOptions [templateOption, relaxedOption, rawOption] $
+cmd :: Command
+cmd = notBareRepo $ withOptions [templateOption, relaxedOption, rawOption] $
command "importfeed" (paramRepeating paramUrl) seek
- SectionCommon "import files from podcast feeds"]
+ SectionCommon "import files from podcast feeds"
templateOption :: Option
templateOption = fieldOption [] "template" paramFormat "template for filenames"
diff --git a/Command/InAnnex.hs b/Command/InAnnex.hs
index 8e792c4bb..29d0750a5 100644
--- a/Command/InAnnex.hs
+++ b/Command/InAnnex.hs
@@ -11,11 +11,12 @@ import Common.Annex
import Command
import Annex.Content
-cmd :: [Command]
-cmd = [noCommit $ command "inannex" (paramRepeating paramKey) seek
- SectionPlumbing "checks if keys are present in the annex"]
+cmd :: Command
+cmd = noCommit $ command "inannex" (paramRepeating paramKey)
+ SectionPlumbing "checks if keys are present in the annex"
+ (commandParser seek)
-seek :: CommandSeek
+seek :: CmdParams -> CommandSeek
seek = withKeys start
start :: Key -> CommandStart
diff --git a/Command/Indirect.hs b/Command/Indirect.hs
index 1d703d2f3..3e10988ed 100644
--- a/Command/Indirect.hs
+++ b/Command/Indirect.hs
@@ -22,10 +22,10 @@ import Annex.CatFile
import Annex.Init
import qualified Command.Add
-cmd :: [Command]
-cmd = [notBareRepo $ noDaemonRunning $
+cmd :: Command
+cmd = notBareRepo $ noDaemonRunning $
command "indirect" paramNothing seek
- SectionSetup "switch repository to indirect mode"]
+ SectionSetup "switch repository to indirect mode"
seek :: CommandSeek
seek = withNothing start
diff --git a/Command/Info.hs b/Command/Info.hs
index e6e0194ce..802aabb56 100644
--- a/Command/Info.hs
+++ b/Command/Info.hs
@@ -78,10 +78,10 @@ emptyStatInfo = StatInfo Nothing Nothing M.empty Nothing
-- a state monad for running Stats in
type StatState = StateT StatInfo Annex
-cmd :: [Command]
-cmd = [noCommit $ dontCheck repoExists $ withOptions (jsonOption : bytesOption : annexedMatchingOptions) $
+cmd :: Command
+cmd = noCommit $ dontCheck repoExists $ withOptions (jsonOption : bytesOption : annexedMatchingOptions) $
command "info" (paramOptional $ paramRepeating paramItem) seek SectionQuery
- "shows information about the specified item or the repository as a whole"]
+ "shows information about the specified item or the repository as a whole"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/Init.hs b/Command/Init.hs
index 23203b035..45ecb92f8 100644
--- a/Command/Init.hs
+++ b/Command/Init.hs
@@ -11,9 +11,9 @@ import Common.Annex
import Command
import Annex.Init
-cmd :: [Command]
-cmd = [dontCheck repoExists $
- command "init" paramDesc seek SectionSetup "initialize git-annex"]
+cmd :: Command
+cmd = dontCheck repoExists $
+ command "init" paramDesc seek SectionSetup "initialize git-annex"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/InitRemote.hs b/Command/InitRemote.hs
index 7831fe22a..4bf5f5312 100644
--- a/Command/InitRemote.hs
+++ b/Command/InitRemote.hs
@@ -19,10 +19,10 @@ import Logs.Trust
import Data.Ord
-cmd :: [Command]
-cmd = [command "initremote"
+cmd :: Command
+cmd = command "initremote"
(paramPair paramName $ paramOptional $ paramRepeating paramKeyValue)
- seek SectionSetup "creates a special (non-git) remote"]
+ seek SectionSetup "creates a special (non-git) remote"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/List.hs b/Command/List.hs
index b9b3a376c..ba27da702 100644
--- a/Command/List.hs
+++ b/Command/List.hs
@@ -23,10 +23,10 @@ import Annex.UUID
import qualified Annex
import Git.Types (RemoteName)
-cmd :: [Command]
-cmd = [noCommit $ withOptions (allrepos : annexedMatchingOptions) $
+cmd :: Command
+cmd = noCommit $ withOptions (allrepos : annexedMatchingOptions) $
command "list" paramPaths seek
- SectionQuery "show which remotes contain files"]
+ SectionQuery "show which remotes contain files"
allrepos :: Option
allrepos = flagOption [] "allrepos" "show all repositories, not only remotes"
diff --git a/Command/Lock.hs b/Command/Lock.hs
index 720169506..2d796ad4f 100644
--- a/Command/Lock.hs
+++ b/Command/Lock.hs
@@ -12,10 +12,10 @@ import Command
import qualified Annex.Queue
import qualified Annex
-cmd :: [Command]
-cmd = [notDirect $ withOptions annexedMatchingOptions $
+cmd :: Command
+cmd = notDirect $ withOptions annexedMatchingOptions $
command "lock" paramPaths seek SectionCommon
- "undo unlock command"]
+ "undo unlock command"
seek :: CommandSeek
seek ps = do
diff --git a/Command/Log.hs b/Command/Log.hs
index 495c43c5a..3d618360d 100644
--- a/Command/Log.hs
+++ b/Command/Log.hs
@@ -38,9 +38,9 @@ data RefChange = RefChange
type Outputter = Bool -> POSIXTime -> [UUID] -> Annex ()
-cmd :: [Command]
-cmd = [withOptions options $
- command "log" paramPaths seek SectionQuery "shows location log"]
+cmd :: Command
+cmd = withOptions options $
+ command "log" paramPaths seek SectionQuery "shows location log"
options :: [Option]
options = passthruOptions ++ [gourceOption] ++ annexedMatchingOptions
diff --git a/Command/LookupKey.hs b/Command/LookupKey.hs
index 6e7f07049..9b7dd3a9b 100644
--- a/Command/LookupKey.hs
+++ b/Command/LookupKey.hs
@@ -13,10 +13,10 @@ import CmdLine.Batch
import Annex.CatFile
import Types.Key
-cmd :: [Command]
-cmd = [withOptions [batchOption] $ notBareRepo $ noCommit $ noMessages $
+cmd :: Command
+cmd = withOptions [batchOption] $ notBareRepo $ noCommit $ noMessages $
command "lookupkey" (paramRepeating paramFile) seek
- SectionPlumbing "looks up key used for file"]
+ SectionPlumbing "looks up key used for file"
seek :: CommandSeek
seek = batchable withStrings start
diff --git a/Command/Map.hs b/Command/Map.hs
index 75af591d5..4328139f1 100644
--- a/Command/Map.hs
+++ b/Command/Map.hs
@@ -25,10 +25,10 @@ import qualified Utility.Dot as Dot
-- a link from the first repository to the second (its remote)
data Link = Link Git.Repo Git.Repo
-cmd :: [Command]
-cmd = [dontCheck repoExists $
+cmd :: Command
+cmd = dontCheck repoExists $
command "map" paramNothing seek SectionQuery
- "generate map of repositories"]
+ "generate map of repositories"
seek :: CommandSeek
seek = withNothing start
diff --git a/Command/Merge.hs b/Command/Merge.hs
index 28e3bbb4d..b451db2af 100644
--- a/Command/Merge.hs
+++ b/Command/Merge.hs
@@ -13,9 +13,9 @@ import qualified Annex.Branch
import qualified Git.Branch
import Command.Sync (prepMerge, mergeLocal)
-cmd :: [Command]
-cmd = [command "merge" paramNothing seek SectionMaintenance
- "automatically merge changes from remotes"]
+cmd :: Command
+cmd = command "merge" paramNothing seek SectionMaintenance
+ "automatically merge changes from remotes"
seek :: CommandSeek
seek ps = do
diff --git a/Command/MetaData.hs b/Command/MetaData.hs
index 10093ab08..d6adb0ad4 100644
--- a/Command/MetaData.hs
+++ b/Command/MetaData.hs
@@ -16,10 +16,10 @@ import Logs.MetaData
import qualified Data.Set as S
import Data.Time.Clock.POSIX
-cmd :: [Command]
-cmd = [withOptions metaDataOptions $
+cmd :: Command
+cmd = withOptions metaDataOptions $
command "metadata" paramPaths seek
- SectionMetaData "sets or gets metadata of a file"]
+ SectionMetaData "sets or gets metadata of a file"
metaDataOptions :: [Option]
metaDataOptions =
diff --git a/Command/Migrate.hs b/Command/Migrate.hs
index 6ffe354d5..d406dbea4 100644
--- a/Command/Migrate.hs
+++ b/Command/Migrate.hs
@@ -18,10 +18,10 @@ import qualified Command.ReKey
import qualified Command.Fsck
import qualified Annex
-cmd :: [Command]
-cmd = [notDirect $ withOptions annexedMatchingOptions $
+cmd :: Command
+cmd = notDirect $ withOptions annexedMatchingOptions $
command "migrate" paramPaths seek
- SectionUtility "switch data to different backend"]
+ SectionUtility "switch data to different backend"
seek :: CommandSeek
seek = withFilesInGit $ whenAnnexed start
diff --git a/Command/Mirror.hs b/Command/Mirror.hs
index 535dc64b6..8ae57da2f 100644
--- a/Command/Mirror.hs
+++ b/Command/Mirror.hs
@@ -16,9 +16,9 @@ import qualified Remote
import Annex.Content
import Annex.NumCopies
-cmd :: [Command]
-cmd = [withOptions mirrorOptions $ command "mirror" paramPaths seek
- SectionCommon "mirror content of files to/from another repository"]
+cmd :: Command
+cmd = withOptions mirrorOptions $ command "mirror" paramPaths seek
+ SectionCommon "mirror content of files to/from another repository"
mirrorOptions :: [Option]
mirrorOptions = fromToOptions ++ [jobsOption] ++ annexedMatchingOptions ++ keyOptions
diff --git a/Command/Move.hs b/Command/Move.hs
index 6867052de..739be4417 100644
--- a/Command/Move.hs
+++ b/Command/Move.hs
@@ -17,9 +17,9 @@ import Annex.UUID
import Annex.Transfer
import Logs.Presence
-cmd :: [Command]
-cmd = [withOptions moveOptions $ command "move" paramPaths seek
- SectionCommon "move content of files to/from another repository"]
+cmd :: Command
+cmd = withOptions moveOptions $ command "move" paramPaths seek
+ SectionCommon "move content of files to/from another repository"
moveOptions :: [Option]
moveOptions = fromToOptions ++ [jobsOption] ++ keyOptions ++ annexedMatchingOptions
diff --git a/Command/NotifyChanges.hs b/Command/NotifyChanges.hs
index 7ec6072dd..55379440c 100644
--- a/Command/NotifyChanges.hs
+++ b/Command/NotifyChanges.hs
@@ -19,11 +19,12 @@ import Control.Concurrent
import Control.Concurrent.Async
import Control.Concurrent.STM
-cmd :: [Command]
-cmd = [noCommit $ command "notifychanges" paramNothing seek SectionPlumbing
- "sends notification when git refs are changed"]
+cmd :: Command
+cmd = noCommit $ command "notifychanges" paramNothing SectionPlumbing
+ "sends notification when git refs are changed"
+ (commandParser seek)
-seek :: CommandSeek
+seek :: CmdParams -> CommandSeek
seek = withNothing start
start :: CommandStart
diff --git a/Command/NumCopies.hs b/Command/NumCopies.hs
index 1e710f561..33db1bbc9 100644
--- a/Command/NumCopies.hs
+++ b/Command/NumCopies.hs
@@ -13,9 +13,9 @@ import Command
import Annex.NumCopies
import Types.Messages
-cmd :: [Command]
-cmd = [command "numcopies" paramNumber seek
- SectionSetup "configure desired number of copies"]
+cmd :: Command
+cmd = command "numcopies" paramNumber seek
+ SectionSetup "configure desired number of copies"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/PreCommit.hs b/Command/PreCommit.hs
index f4dcff269..4f1729394 100644
--- a/Command/PreCommit.hs
+++ b/Command/PreCommit.hs
@@ -28,11 +28,12 @@ import qualified Git.LsFiles as Git
import qualified Data.Set as S
-cmd :: [Command]
-cmd = [command "pre-commit" paramPaths seek SectionPlumbing
- "run by git pre-commit hook"]
+cmd :: Command
+cmd = command "pre-commit" paramPaths SectionPlumbing
+ "run by git pre-commit hook"
+ (commandParser seek)
-seek :: CommandSeek
+seek :: CmdParams -> CommandSeek
seek ps = lockPreCommitHook $ ifM isDirect
( do
-- update direct mode mappings for committed files
diff --git a/Command/Proxy.hs b/Command/Proxy.hs
index 8c11bf770..cfb1f8ba3 100644
--- a/Command/Proxy.hs
+++ b/Command/Proxy.hs
@@ -17,10 +17,10 @@ import qualified Git.Sha
import qualified Git.Ref
import qualified Git.Branch
-cmd :: [Command]
-cmd = [notBareRepo $
+cmd :: Command
+cmd = notBareRepo $
command "proxy" ("-- git command") seek
- SectionPlumbing "safely bypass direct mode guard"]
+ SectionPlumbing "safely bypass direct mode guard"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/ReKey.hs b/Command/ReKey.hs
index 980b27f5a..319f3eda8 100644
--- a/Command/ReKey.hs
+++ b/Command/ReKey.hs
@@ -18,10 +18,10 @@ import Logs.Location
import Utility.CopyFile
import qualified Remote
-cmd :: [Command]
-cmd = [notDirect $ command "rekey"
+cmd :: Command
+cmd = notDirect $ command "rekey"
(paramOptional $ paramRepeating $ paramPair paramPath paramKey)
- seek SectionPlumbing "change keys used for files"]
+ seek SectionPlumbing "change keys used for files"
seek :: CommandSeek
seek = withPairs start
diff --git a/Command/ReadPresentKey.hs b/Command/ReadPresentKey.hs
index 8125ddf7e..6eab893cf 100644
--- a/Command/ReadPresentKey.hs
+++ b/Command/ReadPresentKey.hs
@@ -12,9 +12,9 @@ import Command
import Logs.Location
import Types.Key
-cmd :: [Command]
-cmd = [noCommit $ command "readpresentkey" (paramPair paramKey paramUUID) seek
- SectionPlumbing "read records of where key is present"]
+cmd :: Command
+cmd = noCommit $ command "readpresentkey" (paramPair paramKey paramUUID) seek
+ SectionPlumbing "read records of where key is present"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/RecvKey.hs b/Command/RecvKey.hs
index 8572596d2..574963494 100644
--- a/Command/RecvKey.hs
+++ b/Command/RecvKey.hs
@@ -20,11 +20,12 @@ import qualified Types.Key
import qualified Types.Backend
import qualified Backend
-cmd :: [Command]
-cmd = [noCommit $ command "recvkey" paramKey seek
- SectionPlumbing "runs rsync in server mode to receive content"]
+cmd :: Command
+cmd = noCommit $ command "recvkey" paramKey
+ SectionPlumbing "runs rsync in server mode to receive content"
+ (commandParser seek)
-seek :: CommandSeek
+seek :: CmdParams -> CommandSeek
seek = withKeys start
start :: Key -> CommandStart
diff --git a/Command/RegisterUrl.hs b/Command/RegisterUrl.hs
index 4282db58a..bac5b7740 100644
--- a/Command/RegisterUrl.hs
+++ b/Command/RegisterUrl.hs
@@ -15,10 +15,10 @@ import Logs.Web
import Annex.UUID
import Command.FromKey (mkKey)
-cmd :: [Command]
-cmd = [notDirect $ notBareRepo $
+cmd :: Command
+cmd = notDirect $ notBareRepo $
command "registerurl" (paramPair paramKey paramUrl) seek
- SectionPlumbing "registers an url for a key"]
+ SectionPlumbing "registers an url for a key"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/Reinit.hs b/Command/Reinit.hs
index f201c66bb..948ed3131 100644
--- a/Command/Reinit.hs
+++ b/Command/Reinit.hs
@@ -15,8 +15,9 @@ import Types.UUID
import qualified Remote
cmd :: [Command]
-cmd = [dontCheck repoExists $
- command "reinit" (paramUUID ++ "|" ++ paramDesc) seek SectionUtility "initialize repository, reusing old UUID"]
+cmd = dontCheck repoExists $
+ command "reinit" (paramUUID ++ "|" ++ paramDesc) seek
+ SectionUtility "initialize repository, reusing old UUID"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/Reinject.hs b/Command/Reinject.hs
index de7f6eb3d..09511562f 100644
--- a/Command/Reinject.hs
+++ b/Command/Reinject.hs
@@ -15,8 +15,8 @@ import qualified Command.Fsck
import qualified Backend
cmd :: [Command]
-cmd = [command "reinject" (paramPair "SRC" "DEST") seek
- SectionUtility "sets content of annexed file"]
+cmd = command "reinject" (paramPair "SRC" "DEST") seek
+ SectionUtility "sets content of annexed file"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/RemoteDaemon.hs b/Command/RemoteDaemon.hs
index 2e3d62555..fdd938613 100644
--- a/Command/RemoteDaemon.hs
+++ b/Command/RemoteDaemon.hs
@@ -11,9 +11,9 @@ import Common.Annex
import Command
import RemoteDaemon.Core
-cmd :: [Command]
-cmd = [noCommit $ command "remotedaemon" paramNothing seek SectionPlumbing
- "detects when remotes have changed, and fetches from them"]
+cmd :: Command
+cmd = noCommit $ command "remotedaemon" paramNothing seek SectionPlumbing
+ "detects when remotes have changed, and fetches from them"
seek :: CommandSeek
seek = withNothing start
diff --git a/Command/Repair.hs b/Command/Repair.hs
index d41a074c0..56d696960 100644
--- a/Command/Repair.hs
+++ b/Command/Repair.hs
@@ -16,9 +16,9 @@ import qualified Git.Ref
import Git.Types
import Annex.Version
-cmd :: [Command]
-cmd = [noCommit $ dontCheck repoExists $
- command "repair" paramNothing seek SectionMaintenance "recover broken git repository"]
+cmd :: Command
+cmd = noCommit $ dontCheck repoExists $
+ command "repair" paramNothing seek SectionMaintenance "recover broken git repository"
seek :: CommandSeek
seek = withNothing start
diff --git a/Command/Required.hs b/Command/Required.hs
index 3d9c59279..3cc053b55 100644
--- a/Command/Required.hs
+++ b/Command/Required.hs
@@ -11,7 +11,7 @@ import Command
import Logs.PreferredContent
import qualified Command.Wanted
-cmd :: [Command]
+cmd :: Command
cmd = Command.Wanted.cmd' "required" "get or set required content expression"
requiredContentMapRaw
requiredContentSet
diff --git a/Command/ResolveMerge.hs b/Command/ResolveMerge.hs
index ce199e504..0ecf180b8 100644
--- a/Command/ResolveMerge.hs
+++ b/Command/ResolveMerge.hs
@@ -14,9 +14,9 @@ import Git.Sha
import qualified Git.Branch
import Annex.AutoMerge
-cmd :: [Command]
-cmd = [command "resolvemerge" paramNothing seek SectionPlumbing
- "resolve merge conflicts"]
+cmd :: Command
+cmd = command "resolvemerge" paramNothing seek SectionPlumbing
+ "resolve merge conflicts"
seek :: CommandSeek
seek = withNothing start
diff --git a/Command/RmUrl.hs b/Command/RmUrl.hs
index 5287718c5..2f95ef993 100644
--- a/Command/RmUrl.hs
+++ b/Command/RmUrl.hs
@@ -13,10 +13,10 @@ import Logs.Web
import Annex.UUID
import qualified Remote
-cmd :: [Command]
-cmd = [notBareRepo $
+cmd :: Command
+cmd = notBareRepo $
command "rmurl" (paramPair paramFile paramUrl) seek
- SectionCommon "record file is not available at url"]
+ SectionCommon "record file is not available at url"
seek :: CommandSeek
seek = withPairs start
diff --git a/Command/Schedule.hs b/Command/Schedule.hs
index 91ef2c138..723ade65b 100644
--- a/Command/Schedule.hs
+++ b/Command/Schedule.hs
@@ -17,9 +17,9 @@ import Types.Messages
import qualified Data.Set as S
-cmd :: [Command]
-cmd = [command "schedule" (paramPair paramRemote (paramOptional paramExpression)) seek
- SectionSetup "get or set scheduled jobs"]
+cmd :: Command
+cmd = command "schedule" (paramPair paramRemote (paramOptional paramExpression)) seek
+ SectionSetup "get or set scheduled jobs"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/Semitrust.hs b/Command/Semitrust.hs
index 49004d7f9..3ef2621e0 100644
--- a/Command/Semitrust.hs
+++ b/Command/Semitrust.hs
@@ -11,9 +11,9 @@ import Command
import Types.TrustLevel
import Command.Trust (trustCommand)
-cmd :: [Command]
-cmd = [command "semitrust" (paramRepeating paramRemote) seek
- SectionSetup "return repository to default trust level"]
+cmd :: Command
+cmd = command "semitrust" (paramRepeating paramRemote) seek
+ SectionSetup "return repository to default trust level"
seek :: CommandSeek
seek = trustCommand "semitrust" SemiTrusted
diff --git a/Command/SendKey.hs b/Command/SendKey.hs
index 011785582..78d1f9c1c 100644
--- a/Command/SendKey.hs
+++ b/Command/SendKey.hs
@@ -16,11 +16,12 @@ import Annex.Transfer
import qualified CmdLine.GitAnnexShell.Fields as Fields
import Utility.Metered
-cmd :: [Command]
-cmd = [noCommit $ command "sendkey" paramKey seek
- SectionPlumbing "runs rsync in server mode to send content"]
+cmd :: Command
+cmd = noCommit $ command "sendkey" paramKey
+ SectionPlumbing "runs rsync in server mode to send content"
+ (commandParser seek)
-seek :: CommandSeek
+seek :: CmdParams -> CommandSeek
seek = withKeys start
start :: Key -> CommandStart
diff --git a/Command/SetKey.hs b/Command/SetKey.hs
index d5762dd8c..4f7b5aaf5 100644
--- a/Command/SetKey.hs
+++ b/Command/SetKey.hs
@@ -13,9 +13,9 @@ import Logs.Location
import Annex.Content
import Types.Key
-cmd :: [Command]
-cmd = [command "setkey" (paramPair paramKey paramPath) seek
- SectionPlumbing "sets annexed content for a key"]
+cmd :: Command
+cmd = command "setkey" (paramPair paramKey paramPath) seek
+ SectionPlumbing "sets annexed content for a key"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/SetPresentKey.hs b/Command/SetPresentKey.hs
index 1c41dc2ae..cc2ebc142 100644
--- a/Command/SetPresentKey.hs
+++ b/Command/SetPresentKey.hs
@@ -13,9 +13,9 @@ import Logs.Location
import Logs.Presence.Pure
import Types.Key
-cmd :: [Command]
-cmd = [noCommit $ command "setpresentkey" (paramPair paramKey (paramPair paramUUID "[1|0]")) seek
- SectionPlumbing "change records of where key is present"]
+cmd :: Command
+cmd = noCommit $ command "setpresentkey" (paramPair paramKey (paramPair paramUUID "[1|0]")) seek
+ SectionPlumbing "change records of where key is present"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/Status.hs b/Command/Status.hs
index 26e96a925..248a0b84b 100644
--- a/Command/Status.hs
+++ b/Command/Status.hs
@@ -16,10 +16,10 @@ import qualified Git.LsFiles as LsFiles
import qualified Git.Ref
import qualified Git
-cmd :: [Command]
-cmd = [notBareRepo $ noCommit $ noMessages $ withOptions [jsonOption] $
+cmd :: Command
+cmd = notBareRepo $ noCommit $ noMessages $ withOptions [jsonOption] $
command "status" paramPaths seek SectionCommon
- "show the working tree status"]
+ "show the working tree status"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/Sync.hs b/Command/Sync.hs
index d2c2f95e8..10b9fc2cd 100644
--- a/Command/Sync.hs
+++ b/Command/Sync.hs
@@ -51,10 +51,10 @@ import Utility.Bloom
import Control.Concurrent.MVar
import qualified Data.Map as M
-cmd :: [Command]
-cmd = [withOptions syncOptions $
+cmd :: Command
+cmd = withOptions syncOptions $
command "sync" (paramOptional (paramRepeating paramRemote))
- seek SectionCommon "synchronize local repository with remotes"]
+ seek SectionCommon "synchronize local repository with remotes"
syncOptions :: [Option]
syncOptions =
diff --git a/Command/Test.hs b/Command/Test.hs
index 3c4251460..af02985af 100644
--- a/Command/Test.hs
+++ b/Command/Test.hs
@@ -11,10 +11,10 @@ import Common
import Command
import Messages
-cmd :: [Command]
-cmd = [ noRepo startIO $ dontCheck repoExists $
+cmd :: Command
+cmd = noRepo startIO $ dontCheck repoExists $
command "test" paramNothing seek SectionTesting
- "run built-in test suite"]
+ "run built-in test suite"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/TestRemote.hs b/Command/TestRemote.hs
index b0f2c28bb..cbd2edaf1 100644
--- a/Command/TestRemote.hs
+++ b/Command/TestRemote.hs
@@ -36,10 +36,10 @@ import qualified Data.ByteString as B
import qualified Data.ByteString.Lazy as L
import qualified Data.Map as M
-cmd :: [Command]
-cmd = [ withOptions [sizeOption] $
+cmd :: Command
+cmd = withOptions [sizeOption] $
command "testremote" paramRemote seek SectionTesting
- "test transfers to/from a remote"]
+ "test transfers to/from a remote"
sizeOption :: Option
sizeOption = fieldOption [] "size" paramSize "base key size (default 1MiB)"
diff --git a/Command/TransferInfo.hs b/Command/TransferInfo.hs
index f90e2ad73..44ffe59ad 100644
--- a/Command/TransferInfo.hs
+++ b/Command/TransferInfo.hs
@@ -15,11 +15,12 @@ import Types.Key
import qualified CmdLine.GitAnnexShell.Fields as Fields
import Utility.Metered
-cmd :: [Command]
-cmd = [noCommit $ command "transferinfo" paramKey seek SectionPlumbing
- "updates sender on number of bytes of content received"]
+cmd :: Command
+cmd = noCommit $ command "transferinfo" paramKey SectionPlumbing
+ "updates sender on number of bytes of content received"
+ (commandParser seek)
-seek :: CommandSeek
+seek :: CmdParams -> CommandSeek
seek = withWords start
{- Security:
diff --git a/Command/TransferKey.hs b/Command/TransferKey.hs
index 14e788893..6da2e742b 100644
--- a/Command/TransferKey.hs
+++ b/Command/TransferKey.hs
@@ -15,10 +15,10 @@ import Annex.Transfer
import qualified Remote
import Types.Remote
-cmd :: [Command]
-cmd = [withOptions transferKeyOptions $
+cmd :: Command
+cmd = withOptions transferKeyOptions $
noCommit $ command "transferkey" paramKey seek SectionPlumbing
- "transfers a key from or to a remote"]
+ "transfers a key from or to a remote"
transferKeyOptions :: [Option]
transferKeyOptions = fileOption : fromToOptions
diff --git a/Command/TransferKeys.hs b/Command/TransferKeys.hs
index d490d9be4..a151754df 100644
--- a/Command/TransferKeys.hs
+++ b/Command/TransferKeys.hs
@@ -21,9 +21,9 @@ import Git.Types (RemoteName)
data TransferRequest = TransferRequest Direction Remote Key AssociatedFile
-cmd :: [Command]
-cmd = [command "transferkeys" paramNothing seek
- SectionPlumbing "transfers keys"]
+cmd :: Command
+cmd = command "transferkeys" paramNothing seek
+ SectionPlumbing "transfers keys"
seek :: CommandSeek
seek = withNothing start
diff --git a/Command/Trust.hs b/Command/Trust.hs
index 9d380990e..6f3382c30 100644
--- a/Command/Trust.hs
+++ b/Command/Trust.hs
@@ -16,9 +16,9 @@ import Logs.Group
import qualified Data.Set as S
-cmd :: [Command]
-cmd = [command "trust" (paramRepeating paramRemote) seek
- SectionSetup "trust a repository"]
+cmd :: Command
+cmd = command "trust" (paramRepeating paramRemote) seek
+ SectionSetup "trust a repository"
seek :: CommandSeek
seek = trustCommand "trust" Trusted
diff --git a/Command/Unannex.hs b/Command/Unannex.hs
index 0d88148c8..83e990921 100644
--- a/Command/Unannex.hs
+++ b/Command/Unannex.hs
@@ -22,12 +22,13 @@ import qualified Git.DiffTree as DiffTree
import Utility.CopyFile
import Command.PreCommit (lockPreCommitHook)
-cmd :: [Command]
-cmd = [withOptions annexedMatchingOptions $
- command "unannex" paramPaths seek SectionUtility
- "undo accidential add command"]
+cmd :: Command
+cmd = withOptions annexedMatchingOptions $
+ command "unannex" paramPaths SectionUtility
+ "undo accidential add command"
+ (commandParser seek)
-seek :: CommandSeek
+seek :: CmdParams -> CommandSeek
seek = wrapUnannex . (withFilesInGit $ whenAnnexed start)
wrapUnannex :: Annex a -> Annex a
diff --git a/Command/Undo.hs b/Command/Undo.hs
index 8e6b1c44f..4740aab48 100644
--- a/Command/Undo.hs
+++ b/Command/Undo.hs
@@ -21,10 +21,10 @@ import qualified Git.Command as Git
import qualified Git.Branch
import qualified Command.Sync
-cmd :: [Command]
-cmd = [notBareRepo $
+cmd :: Command
+cmd = notBareRepo $
command "undo" paramPaths seek
- SectionCommon "undo last change to a file or directory"]
+ SectionCommon "undo last change to a file or directory"
seek :: CommandSeek
seek ps = do
diff --git a/Command/Ungroup.hs b/Command/Ungroup.hs
index dd6e8c952..b711a0132 100644
--- a/Command/Ungroup.hs
+++ b/Command/Ungroup.hs
@@ -15,9 +15,9 @@ import Types.Group
import qualified Data.Set as S
-cmd :: [Command]
-cmd = [command "ungroup" (paramPair paramRemote paramDesc) seek
- SectionSetup "remove a repository from a group"]
+cmd :: Command
+cmd = command "ungroup" (paramPair paramRemote paramDesc) seek
+ SectionSetup "remove a repository from a group"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/Uninit.hs b/Command/Uninit.hs
index 4a918070c..64c515464 100644
--- a/Command/Uninit.hs
+++ b/Command/Uninit.hs
@@ -21,9 +21,10 @@ import Utility.FileMode
import System.IO.HVFS
import System.IO.HVFS.Utils
-cmd :: [Command]
-cmd = [addCheck check $ command "uninit" paramPaths seek
- SectionUtility "de-initialize git-annex and clean out repository"]
+cmd :: Command
+cmd = addCheck check $ command "uninit" paramPaths
+ SectionUtility "de-initialize git-annex and clean out repository"
+ (commandParser seek)
check :: Annex ()
check = do
@@ -39,7 +40,7 @@ check = do
revhead = inRepo $ Git.Command.pipeReadStrict
[Param "rev-parse", Param "--abbrev-ref", Param "HEAD"]
-seek :: CommandSeek
+seek :: CmdParams -> CommandSeek
seek ps = do
withFilesNotInGit False (whenAnnexed startCheckIncomplete) ps
Annex.changeState $ \s -> s { Annex.fast = True }
diff --git a/Command/Unlock.hs b/Command/Unlock.hs
index a1b1ce411..98117f5b5 100644
--- a/Command/Unlock.hs
+++ b/Command/Unlock.hs
@@ -13,14 +13,15 @@ import Annex.Content
import Annex.CatFile
import Utility.CopyFile
-cmd :: [Command]
-cmd =
- [ c "unlock" "unlock files for modification"
- , c "edit" "same as unlock"
- ]
- where
- c n = notDirect . withOptions annexedMatchingOptions
- . command n paramPaths seek SectionCommon
+cmd :: Command
+cmd = mkcmd "unlock" "unlock files for modification"
+
+editcmd :: Command
+editcmd = mkcmd "edit" "same as unlock"
+
+mkcmd :: String -> String -> Command
+mkcmd n = notDirect . withOptions annexedMatchingOptions
+ . command n paramPaths seek SectionCommon
seek :: CommandSeek
seek = withFilesInGit $ whenAnnexed start
diff --git a/Command/Untrust.hs b/Command/Untrust.hs
index 92e28b637..220faf85e 100644
--- a/Command/Untrust.hs
+++ b/Command/Untrust.hs
@@ -11,9 +11,9 @@ import Command
import Types.TrustLevel
import Command.Trust (trustCommand)
-cmd :: [Command]
-cmd = [command "untrust" (paramRepeating paramRemote) seek
- SectionSetup "do not trust a repository"]
+cmd :: Command
+cmd = command "untrust" (paramRepeating paramRemote) seek
+ SectionSetup "do not trust a repository"
seek :: CommandSeek
seek = trustCommand "untrust" UnTrusted
diff --git a/Command/Unused.hs b/Command/Unused.hs
index 77a9a92c3..1f84f012f 100644
--- a/Command/Unused.hs
+++ b/Command/Unused.hs
@@ -34,10 +34,11 @@ import Git.FilePath
import Logs.View (is_branchView)
import Annex.BloomFilter
-cmd :: [Command]
-cmd = [withOptions [unusedFromOption, refSpecOption] $
- command "unused" paramNothing seek
- SectionMaintenance "look for unused file content"]
+cmd :: Command
+cmd = withOptions [unusedFromOption, refSpecOption] $
+ command "unused" paramNothing
+ SectionMaintenance "look for unused file content"
+ (commandParser seek)
unusedFromOption :: Option
unusedFromOption = fieldOption ['f'] "from" paramRemote "remote to check for unused content"
@@ -45,7 +46,7 @@ unusedFromOption = fieldOption ['f'] "from" paramRemote "remote to check for unu
refSpecOption :: Option
refSpecOption = fieldOption [] "used-refspec" paramRefSpec "refs to consider used (default: all refs)"
-seek :: CommandSeek
+seek :: CmdParams -> CommandSeek
seek = withNothing start
{- Finds unused content in the annex. -}
diff --git a/Command/Upgrade.hs b/Command/Upgrade.hs
index 081d7ff35..0fa9022ff 100644
--- a/Command/Upgrade.hs
+++ b/Command/Upgrade.hs
@@ -11,10 +11,10 @@ import Common.Annex
import Command
import Upgrade
-cmd :: [Command]
-cmd = [dontCheck repoExists $ -- because an old version may not seem to exist
+cmd :: Command
+cmd = dontCheck repoExists $ -- because an old version may not seem to exist
command "upgrade" paramNothing seek
- SectionMaintenance "upgrade repository layout"]
+ SectionMaintenance "upgrade repository layout"
seek :: CommandSeek
seek = withNothing start
diff --git a/Command/VAdd.hs b/Command/VAdd.hs
index ea98e6639..478eab098 100644
--- a/Command/VAdd.hs
+++ b/Command/VAdd.hs
@@ -12,9 +12,9 @@ import Command
import Annex.View
import Command.View (checkoutViewBranch)
-cmd :: [Command]
-cmd = [notBareRepo $ notDirect $ command "vadd" (paramRepeating "FIELD=GLOB")
- seek SectionMetaData "add subdirs to current view"]
+cmd :: Command
+cmd = notBareRepo $ notDirect $ command "vadd" (paramRepeating "FIELD=GLOB")
+ seek SectionMetaData "add subdirs to current view"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/VCycle.hs b/Command/VCycle.hs
index bf253adc1..31a5f80c2 100644
--- a/Command/VCycle.hs
+++ b/Command/VCycle.hs
@@ -14,10 +14,10 @@ import Types.View
import Logs.View
import Command.View (checkoutViewBranch)
-cmd :: [Command]
-cmd = [notBareRepo $ notDirect $
+cmd :: Command
+cmd = notBareRepo $ notDirect $
command "vcycle" paramNothing seek SectionMetaData
- "switch view to next layout"]
+ "switch view to next layout"
seek :: CommandSeek
seek = withNothing start
diff --git a/Command/VFilter.hs b/Command/VFilter.hs
index fd5ec9630..78f2d9d5c 100644
--- a/Command/VFilter.hs
+++ b/Command/VFilter.hs
@@ -12,9 +12,9 @@ import Command
import Annex.View
import Command.View (paramView, checkoutViewBranch)
-cmd :: [Command]
-cmd = [notBareRepo $ notDirect $
- command "vfilter" paramView seek SectionMetaData "filter current view"]
+cmd :: Command
+cmd = notBareRepo $ notDirect $
+ command "vfilter" paramView seek SectionMetaData "filter current view"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/VPop.hs b/Command/VPop.hs
index 1fb1d7a56..f6fc56b08 100644
--- a/Command/VPop.hs
+++ b/Command/VPop.hs
@@ -16,10 +16,10 @@ import Types.View
import Logs.View
import Command.View (checkoutViewBranch)
-cmd :: [Command]
-cmd = [notBareRepo $ notDirect $
+cmd :: Command
+cmd = notBareRepo $ notDirect $
command "vpop" (paramOptional paramNumber) seek SectionMetaData
- "switch back to previous view"]
+ "switch back to previous view"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/Version.hs b/Command/Version.hs
index 1b96de9d2..3ceef3a60 100644
--- a/Command/Version.hs
+++ b/Command/Version.hs
@@ -17,10 +17,10 @@ import qualified Types.Remote as R
import qualified Remote
import qualified Backend
-cmd :: [Command]
-cmd = [withOptions [rawOption] $
+cmd :: Command
+cmd = withOptions [rawOption] $
noCommit $ noRepo startNoRepo $ dontCheck repoExists $
- command "version" paramNothing seek SectionQuery "show version info"]
+ command "version" paramNothing seek SectionQuery "show version info"
rawOption :: Option
rawOption = flagOption [] "raw" "output only program version"
diff --git a/Command/Vicfg.hs b/Command/Vicfg.hs
index f1a64ba23..9b8177e77 100644
--- a/Command/Vicfg.hs
+++ b/Command/Vicfg.hs
@@ -29,9 +29,9 @@ import Types.StandardGroups
import Types.ScheduledActivity
import Remote
-cmd :: [Command]
-cmd = [command "vicfg" paramNothing seek
- SectionSetup "edit git-annex's configuration"]
+cmd :: Command
+cmd = command "vicfg" paramNothing seek
+ SectionSetup "edit git-annex's configuration"
seek :: CommandSeek
seek = withNothing start
diff --git a/Command/View.hs b/Command/View.hs
index ae2878396..584cf091f 100644
--- a/Command/View.hs
+++ b/Command/View.hs
@@ -17,9 +17,9 @@ import Types.View
import Annex.View
import Logs.View
-cmd :: [Command]
-cmd = [notBareRepo $ notDirect $
- command "view" paramView seek SectionMetaData "enter a view branch"]
+cmd :: Command
+cmd = notBareRepo $ notDirect $
+ command "view" paramView seek SectionMetaData "enter a view branch"
seek :: CommandSeek
seek = withWords start
diff --git a/Command/Wanted.hs b/Command/Wanted.hs
index 07f5ee7c3..215595a52 100644
--- a/Command/Wanted.hs
+++ b/Command/Wanted.hs
@@ -17,7 +17,7 @@ import Types.StandardGroups
import qualified Data.Map as M
-cmd :: [Command]
+cmd :: Command
cmd = cmd' "wanted" "get or set preferred content expression"
preferredContentMapRaw
preferredContentSet
@@ -27,8 +27,8 @@ cmd'
-> String
-> Annex (M.Map UUID PreferredContentExpression)
-> (UUID -> PreferredContentExpression -> Annex ())
- -> [Command]
-cmd' name desc getter setter = [command name pdesc seek SectionSetup desc]
+ -> Command
+cmd' name desc getter setter = command name pdesc seek SectionSetup desc
where
pdesc = paramPair paramRemote (paramOptional paramExpression)
diff --git a/Command/Watch.hs b/Command/Watch.hs
index cf86a5832..0782a4e6e 100644
--- a/Command/Watch.hs
+++ b/Command/Watch.hs
@@ -12,9 +12,9 @@ import Assistant
import Command
import Utility.HumanTime
-cmd :: [Command]
-cmd = [notBareRepo $ withOptions [foregroundOption, stopOption] $
- command "watch" paramNothing seek SectionCommon "watch for changes and autocommit"]
+cmd :: Command
+cmd = notBareRepo $ withOptions [foregroundOption, stopOption] $
+ command "watch" paramNothing seek SectionCommon "watch for changes and autocommit"
seek :: CommandSeek
seek ps = do
diff --git a/Command/WebApp.hs b/Command/WebApp.hs
index e872d4be0..dab8e1e5b 100644
--- a/Command/WebApp.hs
+++ b/Command/WebApp.hs
@@ -37,10 +37,10 @@ import Control.Concurrent.STM
import Network.Socket (HostName)
import System.Environment (getArgs)
-cmd :: [Command]
-cmd = [ withOptions [listenOption] $
+cmd :: Command
+cmd = withOptions [listenOption] $
noCommit $ noRepo startNoRepo $ dontCheck repoExists $ notBareRepo $
- command "webapp" paramNothing seek SectionCommon "launch webapp"]
+ command "webapp" paramNothing seek SectionCommon "launch webapp"
listenOption :: Option
listenOption = fieldOption [] "listen" paramAddress
diff --git a/Command/Whereis.hs b/Command/Whereis.hs
index cfcc8f224..54be0dd18 100644
--- a/Command/Whereis.hs
+++ b/Command/Whereis.hs
@@ -15,10 +15,10 @@ import Remote
import Logs.Trust
import Logs.Web
-cmd :: [Command]
-cmd = [noCommit $ withOptions (jsonOption : annexedMatchingOptions ++ keyOptions) $
+cmd :: Command
+cmd = noCommit $ withOptions (jsonOption : annexedMatchingOptions ++ keyOptions) $
command "whereis" paramPaths seek SectionQuery
- "lists repositories that have file content"]
+ "lists repositories that have file content"
seek :: CommandSeek
seek ps = do
diff --git a/Command/XMPPGit.hs b/Command/XMPPGit.hs
index 2bcb7405e..86cae9ab7 100644
--- a/Command/XMPPGit.hs
+++ b/Command/XMPPGit.hs
@@ -11,10 +11,10 @@ import Common.Annex
import Command
import Assistant.XMPP.Git
-cmd :: [Command]
-cmd = [noCommit $ noRepo startNoRepo $ dontCheck repoExists $
+cmd :: Command
+cmd = noCommit $ noRepo startNoRepo $ dontCheck repoExists $
command "xmppgit" paramNothing seek
- SectionPlumbing "git to XMPP relay"]
+ SectionPlumbing "git to XMPP relay"
seek :: CommandSeek
seek = withWords start