commit: don't include the LF in the header field value When the encoding header changed to be treated as an additional header, the EOL pointer started to point to the byte after the LF, making the git__strndup call copy the LF into the value. Increase the EOL pointer value after copying the data to keep the rest of the semantics but avoid copying LF.
diff --git a/src/commit.c b/src/commit.c
index 9449224..2714f1a 100644
--- a/src/commit.c
+++ b/src/commit.c
@@ -174,8 +174,6 @@ int git_commit__parse_buffer(git_commit *commit, const void *data, size_t len)
const char *eoln = buffer;
while (eoln < buffer_end && *eoln != '\n')
++eoln;
- if (eoln < buffer_end && *eoln == '\n')
- ++eoln;
if (git__prefixcmp(buffer, "encoding ") == 0) {
buffer += strlen("encoding ");
@@ -184,6 +182,9 @@ int git_commit__parse_buffer(git_commit *commit, const void *data, size_t len)
GITERR_CHECK_ALLOC(commit->message_encoding);
}
+ if (eoln < buffer_end && *eoln == '\n')
+ ++eoln;
+
buffer = eoln;
}