Commit 7dc1b1c4 by Pierre-Olivier Latour Committed by Carlos Martín Nieto

Make sure to also update delta->nfiles when merging diffs

When diffs are generated, the value for the 'nfiles' field of 'git_diff_delta'
will be consistent with the value in the 'status' field. Merging diffs can
modify the 'status' field of some deltas and the 'nfiles' field needs to be
updated accordingly.
parent fb6df50b
...@@ -84,11 +84,14 @@ static git_diff_delta *diff_delta__merge_like_cgit( ...@@ -84,11 +84,14 @@ static git_diff_delta *diff_delta__merge_like_cgit(
* index (i.e. not in HEAD nor workdir) is given as empty. * index (i.e. not in HEAD nor workdir) is given as empty.
*/ */
if (dup->status == GIT_DELTA_DELETED) { if (dup->status == GIT_DELTA_DELETED) {
if (a->status == GIT_DELTA_ADDED) if (a->status == GIT_DELTA_ADDED) {
dup->status = GIT_DELTA_UNMODIFIED; dup->status = GIT_DELTA_UNMODIFIED;
dup->nfiles = 2;
}
/* else don't overwrite DELETE status */ /* else don't overwrite DELETE status */
} else { } else {
dup->status = a->status; dup->status = a->status;
dup->nfiles = a->nfiles;
} }
git_oid_cpy(&dup->old_file.id, &a->old_file.id); git_oid_cpy(&dup->old_file.id, &a->old_file.id);
...@@ -118,10 +121,13 @@ static git_diff_delta *diff_delta__merge_like_cgit_reversed( ...@@ -118,10 +121,13 @@ static git_diff_delta *diff_delta__merge_like_cgit_reversed(
return dup; return dup;
if (dup->status == GIT_DELTA_DELETED) { if (dup->status == GIT_DELTA_DELETED) {
if (b->status == GIT_DELTA_ADDED) if (b->status == GIT_DELTA_ADDED) {
dup->status = GIT_DELTA_UNMODIFIED; dup->status = GIT_DELTA_UNMODIFIED;
dup->nfiles = 2;
}
} else { } else {
dup->status = b->status; dup->status = b->status;
dup->nfiles = b->nfiles;
} }
git_oid_cpy(&dup->old_file.id, &b->old_file.id); git_oid_cpy(&dup->old_file.id, &b->old_file.id);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment