# HG changeset patch # User Pierre-Yves David # Date 1456224107 -3600 # Node ID cb6a952efbf48d306a7c82d7fe46115f072cbb1d # Parent 535f2900d0781495abd23cc1b154edfca1df1cac revert: properly revert to ancestor of p2 during merge (issue5052) During merge, added (from one perspective) file can be reported as "modified". To work around that, revert was testing if modified file were present in the parent manifest and marking them as "added" in this case. However, we should be checking against the target revision manifest instead. Otherwise see file as "newly added" even if they exist in the target revision. That revert behavior regressed in 06fbd9518bc5. diff -r 535f2900d078 -r cb6a952efbf4 mercurial/cmdutil.py --- a/mercurial/cmdutil.py Mon Feb 01 12:36:28 2016 +0100 +++ b/mercurial/cmdutil.py Tue Feb 23 11:41:47 2016 +0100 @@ -2846,10 +2846,6 @@ mf = ctx.manifest() if node == p2: parent = p2 - if node == parent: - pmf = mf - else: - pmf = None # need all matching names in dirstate and manifest of target rev, # so have to walk both. do not print errors if files exist in one @@ -2964,11 +2960,7 @@ # in case of merge, files that are actually added can be reported as # modified, we need to post process the result if p2 != nullid: - if pmf is None: - # only need parent manifest in the merge case, - # so do not read by default - pmf = repo[parent].manifest() - mergeadd = dsmodified - set(pmf) + mergeadd = dsmodified - smf dsadded |= mergeadd dsmodified -= mergeadd diff -r 535f2900d078 -r cb6a952efbf4 tests/test-revert.t --- a/tests/test-revert.t Mon Feb 01 12:36:28 2016 +0100 +++ b/tests/test-revert.t Tue Feb 23 11:41:47 2016 +0100 @@ -1076,3 +1076,72 @@ $ cd .. $ diff -U 0 -- content-base-all.txt content-base-explicit.txt | grep _ [1] + +Revert to an ancestor of P2 during a merge (issue5052) +----------------------------------------------------- + +(prepare the repository) + + $ hg init issue5052 + $ cd issue5052 + $ echo '.\.orig' > .hgignore + $ echo 0 > root + $ hg ci -qAm C0 + $ echo 0 > A + $ hg ci -qAm C1 + $ echo 1 >> A + $ hg ci -qm C2 + $ hg up -q 0 + $ echo 1 > B + $ hg ci -qAm C3 + $ hg status --rev 'ancestor(.,2)' --rev 2 + A A + $ hg log -G -T '{rev} ({files})\n' + @ 3 (B) + | + | o 2 (A) + | | + | o 1 (A) + |/ + o 0 (.hgignore root) + + +actual tests: reverting to something else than a merge parent + + $ hg merge + 1 files updated, 0 files merged, 0 files removed, 0 files unresolved + (branch merge, don't forget to commit) + + $ hg status --rev 'p1()' + M A + $ hg status --rev 'p2()' + A B + $ hg status --rev '1' + M A + A B + $ hg revert --rev 1 --all + reverting A + removing B + $ hg status --rev 1 + +From the other parents + + $ hg up -C 'p2()' + 1 files updated, 0 files merged, 0 files removed, 0 files unresolved + $ hg merge + 1 files updated, 0 files merged, 0 files removed, 0 files unresolved + (branch merge, don't forget to commit) + + $ hg status --rev 'p1()' + M B + $ hg status --rev 'p2()' + A A + $ hg status --rev '1' + M A + A B + $ hg revert --rev 1 --all + reverting A + removing B + $ hg status --rev 1 + + $ cd ..