diff options
author | Joey Hess <joey@kitenet.net> | 2014-01-29 13:44:53 -0400 |
---|---|---|
committer | Joey Hess <joey@kitenet.net> | 2014-01-29 13:44:53 -0400 |
commit | 16227a67118b11c2131ee3a3d11ab4633a1cffb5 (patch) | |
tree | dff6588d79bbc0bc577927bcaa225853a1567d6f /CmdLine | |
parent | a0339f209db365651fab21e99ed4f28024a1bcf0 (diff) |
avoid using function named that conflicts with name used in newer version of process library
Diffstat (limited to 'CmdLine')
-rw-r--r-- | CmdLine/Action.hs | 70 | ||||
-rw-r--r-- | CmdLine/Seek.hs | 2 |
2 files changed, 71 insertions, 1 deletions
diff --git a/CmdLine/Action.hs b/CmdLine/Action.hs new file mode 100644 index 000000000..247c658bc --- /dev/null +++ b/CmdLine/Action.hs @@ -0,0 +1,70 @@ +{- git-annex command-line actions + - + - Copyright 2010-2014 Joey Hess <joey@kitenet.net> + - + - Licensed under the GNU GPL version 3 or higher. + -} + +{-# LANGUAGE BangPatterns #-} + +module CmdLine.Action where + +import Common.Annex +import qualified Annex +import Types.Command +import qualified Annex.Queue +import Annex.Exception + +type CommandActionRunner = CommandStart -> CommandCleanup + +{- Runs a command, starting with the check stage, and then + - the seek stage. Finishes by printing the number of commandActions that + - failed. -} +performCommandAction :: Command -> CmdParams -> Annex () +performCommandAction Command { cmdseek = seek, cmdcheck = c, cmdname = name } params = do + mapM_ runCheck c + Annex.changeState $ \s -> s { Annex.errcounter = 0 } + seek params + showerrcount =<< Annex.getState Annex.errcounter + where + showerrcount 0 = noop + showerrcount cnt = error $ name ++ ": " ++ show cnt ++ " failed" + +{- Runs one of the actions needed to perform a command. + - Individual actions can fail without stopping the whole command, + - including by throwing IO errors (but other errors terminate the whole + - command). + - + - This should only be run in the seek stage. -} +commandAction :: CommandActionRunner +commandAction a = handle =<< tryAnnexIO go + where + go = do + Annex.Queue.flushWhenFull + callCommandAction a + handle (Right True) = return True + handle (Right False) = incerr + handle (Left err) = do + showErr err + showEndFail + incerr + incerr = do + Annex.changeState $ \s -> + let ! c = Annex.errcounter s + 1 + ! s' = s { Annex.errcounter = c } + in s' + return False + +{- Runs a single command action through the start, perform and cleanup + - stages, without catching errors. Useful if one command wants to run + - part of another command. -} +callCommandAction :: CommandActionRunner +callCommandAction = start + where + start = stage $ maybe skip perform + perform = stage $ maybe failure cleanup + cleanup = stage $ status + stage = (=<<) + skip = return True + failure = showEndFail >> return False + status r = showEndResult r >> return r diff --git a/CmdLine/Seek.hs b/CmdLine/Seek.hs index d6d7fbc8b..c3becefde 100644 --- a/CmdLine/Seek.hs +++ b/CmdLine/Seek.hs @@ -23,10 +23,10 @@ import qualified Git.Command import qualified Git.LsFiles as LsFiles import qualified Limit import CmdLine.Option +import CmdLine.Action import Logs.Location import Logs.Unused import Annex.CatFile -import RunCommand withFilesInGit :: (FilePath -> CommandStart) -> CommandSeek withFilesInGit a params = seekActions $ prepFiltered a $ |