diff.c: output correct index lines for a split diff
authorJunio C Hamano <gitster@pobox.com>
Mon, 26 Jan 2009 08:08:24 +0000 (00:08 -0800)
committerJunio C Hamano <gitster@pobox.com>
Tue, 27 Jan 2009 08:48:00 +0000 (00:48 -0800)
commitb67b9612e1a90ae093445abeaeff930e9f4cf936
treec8ad5731216e4196f33ccb4ce2ef5085264146a8
parentb938f62a208d24f3d6bed260ceb809cd6b3924d7
diff.c: output correct index lines for a split diff

A patch that changes the filetype (e.g. regular file to symlink) of a path
must be split into a deletion event followed by a creation event, which
means that we need to have two independent metainfo lines for each.
However, the code reused the single set of metainfo lines.

As the blob object names recorded on the index lines are usually not used
nor validated on the receiving end, this is not an issue with normal use
of the resulting patch.  However, when accepting a binary patch to delete
a blob, git-apply verified that the postimage blob object name on the
index line is 0{40}, hence a patch that deletes a regular file blob that
records binary contents to create a blob with different filetype (e.g. a
symbolic link) failed to apply.  "git am -3" also uses the blob object
names recorded on the index line, so it would also misbehave when
synthesizing a preimage tree.

This moves the code to generate metainfo lines around, so that two
independent sets of metainfo lines are used for the split halves.

Additional tests by Jeff King.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
diff.c
t/t4114-apply-typechange.sh