diff options
| author | René Scharfe <rene.scharfe@lsrfire.ath.cx> | 2007-12-20 13:20:15 +0100 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2007-12-26 17:52:32 -0800 | 
| commit | 7ed0988adc0a3cb3f103c105af387e3ac48eea61 (patch) | |
| tree | f917862a230f7c19a470e6988e332129f3bd0fcd | |
| parent | cc216827936e40bc2e8886623fd44f55e0674932 (diff) | |
| download | git-7ed0988adc0a3cb3f103c105af387e3ac48eea61.tar.gz | |
Make "--pretty=format" parser a bit more careful.
When a commit message that does not have a terminating LF is
read in and the memory that was allocated to read it happens to
have a LF immediately after that, the code was not careful and
went past the terminating NUL.
Signed-off-by: Junio C Hamano <gitster@pobox.com>
| -rw-r--r-- | pretty.c | 4 | 
1 files changed, 3 insertions, 1 deletions
| @@ -412,7 +412,7 @@ static void parse_commit_header(struct format_commit_context *context)  		if (i == eol) {  			state++;  			/* strip empty lines */ -			while (msg[eol + 1] == '\n') +			while (msg[eol] == '\n' && msg[eol + 1] == '\n')  				eol++;  		} else if (!prefixcmp(msg + i, "author ")) {  			context->author.off = i + 7; @@ -425,6 +425,8 @@ static void parse_commit_header(struct format_commit_context *context)  			context->encoding.len = eol - i - 9;  		}  		i = eol; +		if (!msg[i]) +			break;  	}  	context->body_off = i;  	context->commit_header_parsed = 1; | 
