diff options
| author | Junio C Hamano <junkio@cox.net> | 2007-01-23 16:51:22 -0800 | 
|---|---|---|
| committer | Junio C Hamano <junkio@cox.net> | 2007-01-23 16:58:13 -0800 | 
| commit | d7ebd53d371153f7a61c0fe9f384c9662b751bf6 (patch) | |
| tree | 08cd9a0e082f05c59109c3cbf029bd94488a1c2d | |
| parent | c9a899256920b3266bb29f9d22bf6b9ab1b5a377 (diff) | |
| download | git-d7ebd53d371153f7a61c0fe9f384c9662b751bf6.tar.gz | |
git-checkout -m: fix merge case
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>
| -rwxr-xr-x | git-checkout.sh | 15 | ||||
| -rwxr-xr-x | t/t7201-co.sh | 28 | 
2 files changed, 32 insertions, 11 deletions
| diff --git a/git-checkout.sh b/git-checkout.sh index e02d4d87f6..c52f352f08 100755 --- a/git-checkout.sh +++ b/git-checkout.sh @@ -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 diff --git a/t/t7201-co.sh b/t/t7201-co.sh index 315fa3564c..867bbd26cb 100755 --- a/t/t7201-co.sh +++ b/t/t7201-co.sh @@ -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 | 
