diff options
author | Junio C Hamano <gitster@pobox.com> | 2009-12-22 12:32:39 -0800 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2009-12-22 12:32:39 -0800 |
commit | 129a5a6deacfe6ffb32291fcd96e0d1567f780b2 (patch) | |
tree | dd00f5a0afb3ef544a530109f5c66311cffe93e9 /builtin-blame.c | |
parent | 0fe19753f26e2747f48d1ec6a1761006d75c2d71 (diff) | |
parent | c8cba79181abc139d7cba364bf868875426fc2c1 (diff) | |
download | git-129a5a6deacfe6ffb32291fcd96e0d1567f780b2.tar.gz |
Merge branch 'maint'
* maint:
Prevent git blame from segfaulting on a missing author name
Diffstat (limited to 'builtin-blame.c')
-rw-r--r-- | builtin-blame.c | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/builtin-blame.c b/builtin-blame.c index d4e25a595d..6408ec8ee6 100644 --- a/builtin-blame.c +++ b/builtin-blame.c @@ -1305,6 +1305,7 @@ static void get_ac_line(const char *inbuf, const char *what, error_out: /* Ugh */ *tz = "(unknown)"; + strcpy(person, *tz); strcpy(mail, *tz); *time = 0; return; @@ -1314,20 +1315,26 @@ static void get_ac_line(const char *inbuf, const char *what, tmp = person; tmp += len; *tmp = 0; - while (*tmp != ' ') + while (person < tmp && *tmp != ' ') tmp--; + if (tmp <= person) + goto error_out; *tz = tmp+1; tzlen = (person+len)-(tmp+1); *tmp = 0; - while (*tmp != ' ') + while (person < tmp && *tmp != ' ') tmp--; + if (tmp <= person) + goto error_out; *time = strtoul(tmp, NULL, 10); timepos = tmp; *tmp = 0; - while (*tmp != ' ') + while (person < tmp && *tmp != ' ') tmp--; + if (tmp <= person) + return; mailpos = tmp + 1; *tmp = 0; maillen = timepos - tmp; |