]> git.ipfire.org Git - thirdparty/git.git/commit
fsck: properly bound "invalid tag name" error message
authorJeff King <peff@peff.net>
Mon, 8 Dec 2014 05:48:13 +0000 (00:48 -0500)
committerJunio C Hamano <gitster@pobox.com>
Tue, 9 Dec 2014 19:54:25 +0000 (11:54 -0800)
commit7add441984063d2c34fa8de252b8ceb803e7981a
tree33d1406102d6d660c798dfd4ac79b23badc655b7
parentf99b7af661f89865f918e52223a3bdaf312a0de0
fsck: properly bound "invalid tag name" error message

When we detect an invalid tag-name header in a tag object,
like, "tag foo bar\n", we feed the pointer starting at "foo
bar" to a printf "%s" formatter. This shows the name, as we
want, but then it keeps printing the rest of the tag buffer,
rather than stopping at the end of the line.

Our tests did not notice because they look only for the
matching line, but the bug is that we print much more than
we wanted to. So we also adjust the test to be more exact.

Note that when fscking tags with "index-pack --strict", this
is even worse. index-pack does not add a trailing
NUL-terminator after the object, so we may actually read
past the buffer and print uninitialized memory. Running
t5302 with valgrind does notice the bug for that reason.

Signed-off-by: Jeff King <peff@peff.net>
Acked-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
fsck.c
t/t1450-fsck.sh