Merge branch 'jc/diff-b-m'
Fix long-standing bug in "diff -B -M" output. * jc/diff-b-m: diff -B -M: fix output for "copy and then rewrite" case
This commit is contained in:
commit
f41157e649
@ -246,6 +246,13 @@ static void merge_broken(struct diff_filepair *p,
|
||||
|
||||
dp = diff_queue(outq, d->one, c->two);
|
||||
dp->score = p->score;
|
||||
/*
|
||||
* We will be one extra user of the same src side of the
|
||||
* broken pair, if it was used as the rename source for other
|
||||
* paths elsewhere. Increment to mark that the path stays
|
||||
* in the resulting tree.
|
||||
*/
|
||||
d->one->rename_used++;
|
||||
diff_free_filespec_data(d->two);
|
||||
diff_free_filespec_data(c->one);
|
||||
free(d);
|
||||
|
@ -123,10 +123,10 @@ test_expect_success \
|
||||
'git diff-index -B -M "$tree" >current'
|
||||
|
||||
# file0 changed from regular to symlink. file1 is very close to the preimage of file0.
|
||||
# because we break file0, file1 can become a rename of it.
|
||||
# the change does not make file0 disappear, so file1 is denoted as a copy of file0
|
||||
cat >expected <<\EOF
|
||||
:100644 120000 f5deac7be59e7eeab8657fd9ae706fd6a57daed2 67be421f88824578857624f7b3dc75e99a8a1481 T file0
|
||||
:100644 100644 6ff87c4664981e4397625791c8ea3bbb5f2279a3 f5deac7be59e7eeab8657fd9ae706fd6a57daed2 R file0 file1
|
||||
:100644 100644 6ff87c4664981e4397625791c8ea3bbb5f2279a3 f5deac7be59e7eeab8657fd9ae706fd6a57daed2 C file0 file1
|
||||
EOF
|
||||
|
||||
test_expect_success \
|
||||
|
@ -76,7 +76,8 @@ test_expect_success 'moves and renames' '
|
||||
|
||||
git diff-tree three four -r --name-status -B -M | sort >actual &&
|
||||
{
|
||||
echo "R100 foo bar"
|
||||
# see -B -M (#6) in t4008
|
||||
echo "C100 foo bar"
|
||||
echo "T100 foo"
|
||||
} | sort >expect &&
|
||||
test_cmp expect actual
|
||||
|
Loading…
Reference in New Issue
Block a user