diff options
author | Jeff King <peff@peff.net> | 2014-06-16 20:07:07 -0400 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2014-06-17 13:41:41 -0700 |
commit | aa4b78d483a918ebee810993e420b4697b0de4d3 (patch) | |
tree | 906dc9439e162ce18b6bdb5e67c0076b408f14a3 /pretty.c | |
parent | 06ca0f45a063f7186cce96a58a5fb6bef16ec204 (diff) | |
download | git-aa4b78d483a918ebee810993e420b4697b0de4d3.tar.gz git-aa4b78d483a918ebee810993e420b4697b0de4d3.tar.xz |
pretty: avoid reading past end-of-string with "%G"
If the user asks for --format=%G with nothing else, we
correctly realize that "%G" is not a valid placeholder (it
should be "%G?", "%GK", etc). But we still tell the
strbuf_expand code that we consumed 2 characters, causing it
to jump over the trailing NUL and output garbage.
This also fixes the case where "%GX" would be consumed (and
produce no output). In other cases, we pass unrecognized
placeholders through to the final string.
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'pretty.c')
-rw-r--r-- | pretty.c | 2 |
1 files changed, 2 insertions, 0 deletions
@@ -1267,6 +1267,8 @@ static size_t format_commit_one(struct strbuf *sb, /* in UTF-8 */ if (c->signature_check.key) strbuf_addstr(sb, c->signature_check.key); break; + default: + return 0; } return 2; } |