diff: use blob path for blob/file diffs
commit30d005c02014680403b5d35ef274047ab91fa5bd
authorJeff King <peff@peff.net>
Fri, 19 May 2017 12:59:34 +0000 (19 08:59 -0400)
committerJunio C Hamano <gitster@pobox.com>
Wed, 24 May 2017 01:59:27 +0000 (24 10:59 +0900)
tree9e815f072822563da73f47a438e0c601d13d5008
parent158b06caee5f9ea2987f444b8e49bd2d678b187d
diff: use blob path for blob/file diffs

When we diff a blob against a working tree file like:

  git diff HEAD:Makefile Makefile

we always use the working tree filename for both sides of
the diff. In most cases that's fine, as the two would be the
same anyway, as above. And until recently, we used the
"name" for the blob, not the path, which would have the
messy "HEAD:" on the beginning.

But when they don't match, like:

  git diff HEAD:old_path new_path

it makes sense to show both names.

This patch uses the blob's path field if it's available, and
otherwise falls back to using the filename (in preference to
the blob's name, which is likely to be garbage like a raw
sha1).

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