]> git.ipfire.org Git - thirdparty/git.git/commitdiff
add-patch: use normalize_marker() when recounting edited hunk
authorPhillip Wood <phillip.wood@dunelm.org.uk>
Sat, 20 Jul 2024 16:02:00 +0000 (16:02 +0000)
committerJunio C Hamano <gitster@pobox.com>
Sat, 20 Jul 2024 23:29:15 +0000 (16:29 -0700)
After the user has edited a hunk the number of lines in the pre- and
post- image lines is recounted the hunk header can be updated before
passing the hunk to "git apply". The recounting code correctly handles
empty context lines where the leading ' ' is omitted by treating '\n'
and '\r' as context lines.

Update this code to use normalize_marker() so that the handling of empty
context lines is consistent with the rest of the hunk parsing
code. There is a small change in behavior as normalize_marker() only
treats "\r\n" as an empty context line rather than any line starting
with '\r'. This should not matter in practice as Macs have used Unix
line endings since MacOs 10 was released in 2001 and if it transpires
that someone is still using an earlier version of MacOs where lines end
with '\r' then we will need to change the handling of '\r' in
normalize_marker() anyway.

Signed-off-by: Phillip Wood <phillip.wood@dunelm.org.uk>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
add-patch.c

index 1c28a7fa1f706d309c5733a51edb0c59e08eaecd..537cf400e6e9d5eae65c4e7c8ff9d6036d7b565e 100644 (file)
@@ -1178,14 +1178,14 @@ static ssize_t recount_edited_hunk(struct add_p_state *s, struct hunk *hunk,
 
        header->old_count = header->new_count = 0;
        for (i = hunk->start; i < hunk->end; ) {
-               switch (s->plain.buf[i]) {
+               switch(normalize_marker(&s->plain.buf[i])) {
                case '-':
                        header->old_count++;
                        break;
                case '+':
                        header->new_count++;
                        break;
-               case ' ': case '\r': case '\n':
+               case ' ':
                        header->old_count++;
                        header->new_count++;
                        break;