diff-highlight: avoid highlighting combined diffs
commit3dbfe2b8ae94cbdae5f3d32581aedaa5510fdc87
authorJeff King <peff@peff.net>
Wed, 31 Aug 2016 05:05:38 +0000 (31 01:05 -0400)
committerJunio C Hamano <gitster@pobox.com>
Wed, 31 Aug 2016 16:59:53 +0000 (31 09:59 -0700)
tree764f91156b2707cb6dc7c5a4cc4f8784203411bc
parent1b5290b125fca91f620aadbc1a5e3c559d4a5313
diff-highlight: avoid highlighting combined diffs

The algorithm in diff-highlight only understands how to look
at two sides of a diff; it cannot correctly handle combined
diffs with multiple preimages. Often highlighting does not
trigger at all for these diffs because the line counts do
not match up.  E.g., if we see:

  - ours
   -theirs
  ++resolved

we would not bother highlighting; it naively looks like a
single line went away, and then a separate hunk added
another single line.

But of course there are exceptions. E.g., if the other side
deleted the line, we might see:

  - ours
  ++resolved

which looks like we dropped " ours" and added "+resolved".
This is only a small highlighting glitch (we highlight the
space and the "+" along with the content), but it's also the
tip of the iceberg. Even if we learned to find the true
content here (by noticing we are in a 3-way combined diff
and marking _two_ characters from the front of the line as
uninteresting), there are other more complicated cases where
we really do need to handle a 3-way hunk.

Let's just punt for now; we can recognize combined diffs by
the presence of extra "@" symbols in the hunk header, and
treat them as non-diff content.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
contrib/diff-highlight/diff-highlight
contrib/diff-highlight/t/t9400-diff-highlight.sh