diff options
author | Joey Hess <joeyh@joeyh.name> | 2017-12-28 17:29:38 -0400 |
---|---|---|
committer | Joey Hess <joeyh@joeyh.name> | 2017-12-28 17:31:16 -0400 |
commit | a911948e63d6677a1da7c3000ad5719119d0830a (patch) | |
tree | bfb229f5a289026be3bc3ccb310dea771fcc216c /CmdLine | |
parent | 29b1e4c69e96b1dab8ce8ae0579e988b17d33325 (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.hs | 13 |
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' |