Skip to content

Commit

Permalink
update cache for conflicting submodule entries
Browse files Browse the repository at this point in the history
When merging merge bases during a recursive merge we do not want to
leave any unmerged entries. Otherwise we cannot create a temporary
tree for the recursive merge to work with.

We failed to do so in case of a submodule conflict between merge
bases, causing a NULL pointer dereference in the next step of the
recursive merge.

Signed-off-by: Clemens Buchacher <drizzd@aon.at>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
  • Loading branch information
Clemens Buchacher authored and Junio C Hamano committed Apr 5, 2009
1 parent f37ae35 commit 0eb6574
Show file tree
Hide file tree
Showing 2 changed files with 4 additions and 3 deletions.
5 changes: 3 additions & 2 deletions merge-recursive.c
Original file line number Diff line number Diff line change
Expand Up @@ -1123,10 +1123,11 @@ static int process_entry(struct merge_options *o,
clean_merge = mfi.clean;
if (mfi.clean)
update_file(o, 1, mfi.sha, mfi.mode, path);
else if (S_ISGITLINK(mfi.mode))
else if (S_ISGITLINK(mfi.mode)) {
output(o, 1, "CONFLICT (submodule): Merge conflict in %s "
"- needs %s", path, sha1_to_hex(b.sha1));
else {
update_file(o, 0, mfi.sha, mfi.mode, path);
} else {
output(o, 1, "CONFLICT (%s): Merge conflict in %s",
reason, path);

Expand Down
2 changes: 1 addition & 1 deletion t/t7405-submodule-merge.sh
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,7 @@ test_expect_failure 'merging with modify/modify conflict' '
'

test_expect_failure 'merging with a modify/modify conflict between merge bases' '
test_expect_success 'merging with a modify/modify conflict between merge bases' '
git reset --hard HEAD &&
git checkout -b test2 c &&
Expand Down

0 comments on commit 0eb6574

Please sign in to comment.