[PATCH 6 of 7 mergedriver] filemerge: don't attempt to premerge change/delete conflicts

Siddharth Agarwal sid0 at fb.com
Thu Nov 19 15:33:58 CST 2015


# HG changeset patch
# User Siddharth Agarwal <sid0 at fb.com>
# Date 1447487760 28800
#      Fri Nov 13 23:56:00 2015 -0800
# Node ID 2bdd5467ac12506533d343f811efef690b88261c
# Parent  eee6801761dfd7f869d0d72a06e10a2621aec156
# Available At http://42.netv6.net/sid0-wip/hg/
#              hg pull http://42.netv6.net/sid0-wip/hg/ -r 2bdd5467ac12
filemerge: don't attempt to premerge change/delete conflicts

This is mostly for completeness' sake -- at the moment we don't support any
tools for change/delete conflicts that would do a premerge.

diff --git a/mercurial/filemerge.py b/mercurial/filemerge.py
--- a/mercurial/filemerge.py
+++ b/mercurial/filemerge.py
@@ -287,9 +287,9 @@ def _ifail(repo, mynode, orig, fcd, fco,
     used to resolve these conflicts."""
     return 1, False
 
-def _premerge(repo, toolconf, files, labels=None):
+def _premerge(repo, fcd, fco, fca, toolconf, files, labels=None):
     tool, toolpath, binary, symlink = toolconf
-    if symlink:
+    if symlink or fcd.isabsent() or fco.isabsent():
         return 1
     a, b, c, back = files
 
@@ -610,7 +610,7 @@ def _filemerge(premerge, repo, mynode, o
             labels = _formatlabels(repo, fcd, fco, fca, labels)
 
         if premerge and mergetype == fullmerge:
-            r = _premerge(repo, toolconf, files, labels=labels)
+            r = _premerge(repo, fcd, fco, fca, toolconf, files, labels=labels)
             # complete if premerge successful (r is 0)
             return not r, r, False
 


More information about the Mercurial-devel mailing list