summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorElijah Newren <newren@gmail.com>2010-09-20 02:28:55 -0600
committerJunio C Hamano <gitster@pobox.com>2010-09-29 17:37:03 -0700
commit384c166807e6eefbefa3e9f253216b2aee6d912a (patch)
tree9ffc2737d2c2318d44ceac4482adfb02bb3f1c6e
parent2ff739f9d2fd2f34e7a7bfb9b5f2d1d2b2ec5326 (diff)
downloadgit-384c166807e6eefbefa3e9f253216b2aee6d912a.tar.gz
merge-recursive: Have process_entry() skip D/F or rename entries
If an entry has an associated rename_df_conflict_info, skip it and allow it to be processed by process_df_entry(). Signed-off-by: Elijah Newren <newren@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
-rw-r--r--merge-recursive.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/merge-recursive.c b/merge-recursive.c
index 2ba05a5b59..319780458e 100644
--- a/merge-recursive.c
+++ b/merge-recursive.c
@@ -1267,6 +1267,9 @@ static int process_entry(struct merge_options *o,
unsigned char *a_sha = stage_sha(entry->stages[2].sha, a_mode);
unsigned char *b_sha = stage_sha(entry->stages[3].sha, b_mode);
+ if (entry->rename_df_conflict_info)
+ return 1; /* Such cases are handled elsewhere. */
+
entry->processed = 1;
if (o_sha && (!a_sha || !b_sha)) {
/* Case A: Deleted in one */