Code

git-checkout -m: fix merge case
authorJunio C Hamano <junkio@cox.net>
Wed, 24 Jan 2007 00:51:22 +0000 (16:51 -0800)
committerJunio C Hamano <junkio@cox.net>
Wed, 24 Jan 2007 00:58:13 +0000 (16:58 -0800)
Commit c1a4278e switched the "merging checkout" implementation
from 3-way read-tree to merge-recursive, but forgot that
merge-recursive will signal an unmerged state with its own exit
status code.  This prevented the clean-up phase (paths cleanly
merged should not be updated in the index) from running.

Signed-off-by: Junio C Hamano <junkio@cox.net>
git-checkout.sh
t/t7201-co.sh

index e02d4d87f622bf73ad04c356ff15ac6e0a626aa6..c52f352f085728f0ce58895538b6f5ecff8c6d45 100755 (executable)
@@ -200,17 +200,12 @@ else
        # Match the index to the working tree, and do a three-way.
        git diff-files --name-only | git update-index --remove --stdin &&
        work=`git write-tree` &&
-       git read-tree --reset -u $new &&
-       eval GITHEAD_$new=${new_name:-${branch:-$new}} GITHEAD_$work=local &&
-       export GITHEAD_$new GITHEAD_$work &&
-       git merge-recursive $old -- $new $work || exit
+       git read-tree --reset -u $new || exit
 
-       if result=`git write-tree 2>/dev/null`
-       then
-           echo >&2 "Trivially automerged."
-       else
-           git merge-index -o git-merge-one-file -a
-       fi
+       eval GITHEAD_$new=${new_name:-${branch:-$new}} &&
+       eval GITHEAD_$work=local &&
+       export GITHEAD_$new GITHEAD_$work &&
+       git merge-recursive $old -- $new $work
 
        # Do not register the cleanly merged paths in the index yet.
        # this is not a real merge before committing, but just carrying
index 315fa3564c744e2601fc1469516337b436d056cb..867bbd26cbbacbe03ef76cadb6ff34976c324da5 100755 (executable)
@@ -100,7 +100,33 @@ test_expect_success "checkout -m with dirty tree, renamed" '
        git checkout -m renamer &&
        fill 1 3 4 5 7 8 >expect &&
        diff expect uno &&
-       ! test -f one
+       ! test -f one &&
+       git diff --cached >current &&
+       ! test -s current
+
+'
+
+test_expect_success 'checkout -m with merge conflict' '
+
+       git checkout -f master && git clean &&
+
+       fill 1 T 3 4 5 6 S 8 >one &&
+       if git checkout renamer
+       then
+               echo Not happy
+               false
+       else
+               echo "happy - failed correctly"
+       fi &&
+
+       git checkout -m renamer &&
+
+       git diff master:one :3:uno |
+       sed -e "1,/^@@/d" -e "/^ /d" -e "s/^-/d/" -e "s/^+/a/" >current &&
+       fill d2 aT d7 aS >expect &&
+       diff current expect &&
+       git diff --cached two >current &&
+       ! test -s current
 '
 
 test_done