pretty: simplify input line length calculation in pp_user_info()

Instead of searching for LF and NUL with two strchr() calls use a single
strchrnul() call.  We don't need to check if the returned pointer is NULL
because either we'll find the NUL at the end of line, or the caller
forgot to NUL-terminate the string and we'll overrun the buffer in any
case.  Also we don't need to pass LF or NUL to split_ident_line() as it
ignores it anyway.

Signed-off-by: Rene Scharfe <rene.scharfe@lsrfire.ath.cx>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
maint
René Scharfe 2013-04-25 21:40:25 +02:00 committed by Junio C Hamano
parent de5abe9fe9
commit 30e77bcb50
1 changed files with 2 additions and 11 deletions

View File

@ -413,7 +413,6 @@ void pp_user_info(const struct pretty_print_context *pp,
struct strbuf name;
struct strbuf mail;
struct ident_split ident;
int linelen;
char *line_end;
const char *mailbuf, *namebuf;
size_t namelen, maillen;
@ -422,17 +421,9 @@ void pp_user_info(const struct pretty_print_context *pp,
if (pp->fmt == CMIT_FMT_ONELINE)
return;

line_end = strchr(line, '\n');
if (!line_end) {
line_end = strchr(line, '\0');
if (!line_end)
line_end = strchrnul(line, '\n');
if (split_ident_line(&ident, line, line_end - line))
return;
}

linelen = ++line_end - line;
if (split_ident_line(&ident, line, linelen))
return;


mailbuf = ident.mail_begin;
maillen = ident.mail_end - ident.mail_begin;