summaryrefslogtreecommitdiff
path: root/Command/Sync.hs
diff options
context:
space:
mode:
Diffstat (limited to 'Command/Sync.hs')
-rw-r--r--Command/Sync.hs13
1 files changed, 7 insertions, 6 deletions
diff --git a/Command/Sync.hs b/Command/Sync.hs
index 759afed82..b146379d1 100644
--- a/Command/Sync.hs
+++ b/Command/Sync.hs
@@ -167,11 +167,7 @@ mergeFrom branch = do
ok <- inRepo $ Git.Merge.mergeNonInteractive branch
if ok
then return ok
- else do
- merged <- resolveMerge
- when merged $
- showNote "merge conflict automatically resolved"
- return merged
+ else resolveMerge
{- Resolves a conflicted merge. It's important that any conflicts be
- resolved in a way that itself avoids later merge conflicts, since
@@ -191,7 +187,12 @@ mergeFrom branch = do
resolveMerge :: Annex Bool
resolveMerge = do
top <- fromRepo Git.repoPath
- all id <$> (mapM resolveMerge' =<< inRepo (LsFiles.unmerged [top]))
+ merged <- all id <$> (mapM resolveMerge' =<< inRepo (LsFiles.unmerged [top]))
+ when merged $ do
+ Annex.Queue.flush
+ void $ inRepo $ Git.Command.runBool "commit"
+ [Param "-m", Param "git-annex automatic merge resolution"]
+ return merged
resolveMerge' :: LsFiles.Unmerged -> Annex Bool
resolveMerge' u