Comments
Patch
@@ -34,6 +34,7 @@ from . import (
graphmod,
match as matchmod,
mdiff,
+ mergeutil,
obsolete,
patch,
pathutil,
@@ -3212,6 +3213,11 @@ def amend(ui, repo, old, extra, pats, op
if subs:
subrepo.writestate(repo, newsubstate)
+ # avoid cycle (TODO: should be removed in default branch)
+ from . import merge as mergemod
+ ms = mergemod.mergestate.read(repo)
+ mergeutil.checkunresolved(ms)
+
filestoamend = set(f for f in wctx.files() if matcher(f))
changes = (len(filestoamend) > 0)
@@ -415,6 +415,23 @@ Refuse to amend during a merge:
[255]
$ hg ci -m 'merge'
+Refuse to amend if there is a merge conflict (issue5805):
+
+ $ hg up -q foo
+ $ echo c > a
+ $ hg up default -t :fail
+ 0 files updated, 0 files merged, 0 files removed, 1 files unresolved
+ use 'hg resolve' to retry unresolved file merges
+ [1]
+ $ hg resolve -l
+ U a
+
+ $ hg ci --amend
+ abort: unresolved merge conflicts (see 'hg help resolve')
+ [255]
+
+ $ hg up -qC .
+
Follow copies/renames:
$ hg mv b c