aboutsummaryrefslogtreecommitdiff
path: root/CmdLine
diff options
context:
space:
mode:
authorGravatar Joey Hess <joeyh@joeyh.name>2017-12-28 17:29:38 -0400
committerGravatar Joey Hess <joeyh@joeyh.name>2017-12-28 17:31:16 -0400
commita911948e63d6677a1da7c3000ad5719119d0830a (patch)
treebfb229f5a289026be3bc3ccb310dea771fcc216c /CmdLine
parent29b1e4c69e96b1dab8ce8ae0579e988b17d33325 (diff)
Fix bug introduced in version 6.20171018 that caused some commands to print out "ok" twice after processing a file.
This commit was sponsored by Boyd Stephen Smith Jr. on Patreon
Diffstat (limited to 'CmdLine')
-rw-r--r--CmdLine/Action.hs13
1 files changed, 9 insertions, 4 deletions
diff --git a/CmdLine/Action.hs b/CmdLine/Action.hs
index 2e0bc2ba2..036f47dd3 100644
--- a/CmdLine/Action.hs
+++ b/CmdLine/Action.hs
@@ -149,15 +149,20 @@ callCommandAction = fromMaybe True <$$> callCommandAction'
{- Like callCommandAction, but returns Nothing when the command did not
- perform any action. -}
callCommandAction' :: CommandStart -> Annex (Maybe Bool)
-callCommandAction' = start
+callCommandAction' a = callCommandActionQuiet a >>= \case
+ Nothing -> return Nothing
+ Just r -> implicitMessage (showEndResult r) >> return (Just r)
+
+callCommandActionQuiet :: CommandStart -> Annex (Maybe Bool)
+callCommandActionQuiet = start
where
start = stage $ maybe skip perform
perform = stage $ maybe failure cleanup
cleanup = stage $ status
stage = (=<<)
skip = return Nothing
- failure = implicitMessage showEndFail >> return (Just False)
- status r = implicitMessage (showEndResult r) >> return (Just r)
+ failure = return (Just False)
+ status = return . Just
{- Do concurrent output when that has been requested. -}
allowConcurrentOutput :: Annex a -> Annex a
@@ -188,7 +193,7 @@ onlyActionOn k a = onlyActionOn' k run
where
-- Run whole action, not just start stage, so other threads
-- block until it's done.
- run = callCommandAction' a >>= \case
+ run = callCommandActionQuiet a >>= \case
Nothing -> return Nothing
Just r' -> return $ Just $ return $ Just $ return r'