add -p: detect more mismatches between plain vs colored diffs
commitb6633a005384a8c120d34a8a79a5a5fe9d8719d7
authorJohannes Schindelin <johannes.schindelin@gmx.de>
Thu, 1 Sep 2022 15:42:17 +0000 (1 15:42 +0000)
committerJunio C Hamano <gitster@pobox.com>
Thu, 1 Sep 2022 16:49:45 +0000 (1 09:49 -0700)
tree58520b4f0da6962b6566501a3e21c1ea47f44d6b
parentad60dddad72dfb8367bd695028b5b8dc6c33661b
add -p: detect more mismatches between plain vs colored diffs

When parsing the colored version of a diff, the interactive `add`
command really relies on the colored version having the same number of
lines as the plain (uncolored) version. That is an invariant.

We already have code to verify correctly when the colored diff has less
lines than the plain diff. Modulo an off-by-one bug: If the last diff
line has no matching colored one, the code pretends to succeed, still.

To make matters worse, when we adjusted the test in 1e4ffc765db (t3701:
adjust difffilter test, 2020-01-14), we did not catch this because `add
-p` fails for a _different_ reason: it does not find any colored hunk
header that contains a parseable line range.

If we change the test case so that the line range _can_ be parsed, the
bug is exposed.

Let's address all of the above by

- fixing the off-by-one,

- adjusting the test case to allow `add -p` to parse the line range

- making the test case more stringent by verifying that the expected
  error message is shown

Also adjust a misleading code comment about the now-fixed code.

Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
add-patch.c
t/t3701-add-interactive.sh