Skip to content

Commit

Permalink
Merge branch 'jk/split-broken-ident' into maint
Browse files Browse the repository at this point in the history
The fall-back parsing of commit objects with broken author or
committer lines were less robust than ideal in picking up the
timestamps.

* jk/split-broken-ident:
  split_ident: parse timestamp from end of line
  • Loading branch information
gitster committed Nov 7, 2013
2 parents 0faff47 + 03818a4 commit 0ceb753
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 3 deletions.
16 changes: 15 additions & 1 deletion ident.c
Original file line number Diff line number Diff line change
Expand Up @@ -233,7 +233,21 @@ int split_ident_line(struct ident_split *split, const char *line, int len)
if (!split->mail_end)
return status;

for (cp = split->mail_end + 1; cp < line + len && isspace(*cp); cp++)
/*
* Look from the end-of-line to find the trailing ">" of the mail
* address, even though we should already know it as split->mail_end.
* This can help in cases of broken idents with an extra ">" somewhere
* in the email address. Note that we are assuming the timestamp will
* never have a ">" in it.
*
* Note that we will always find some ">" before going off the front of
* the string, because will always hit the split->mail_end closing
* bracket.
*/
for (cp = line + len - 1; *cp != '>'; cp--)
;

for (cp = cp + 1; cp < line + len && isspace(*cp); cp++)
;
if (line + len <= cp)
goto person_only;
Expand Down
9 changes: 7 additions & 2 deletions t/t4212-log-corrupt.sh
Original file line number Diff line number Diff line change
Expand Up @@ -13,11 +13,16 @@ test_expect_success 'setup' '
git update-ref refs/heads/broken_email $(cat broken_email.hash)
'

test_expect_success 'fsck notices broken commit' '
git fsck 2>actual &&
test_i18ngrep invalid.author actual
'

test_expect_success 'git log with broken author email' '
{
echo commit $(cat broken_email.hash)
echo "Author: A U Thor <[email protected]>"
echo "Date: Thu Jan 1 00:00:00 1970 +0000"
echo "Date: Thu Apr 7 15:13:13 2005 -0700"
echo
echo " foo"
} >expect.out &&
Expand All @@ -30,7 +35,7 @@ test_expect_success 'git log with broken author email' '
'

test_expect_success 'git log --format with broken author email' '
echo "A U [email protected]+" >expect.out &&
echo "A U [email protected]+Thu Apr 7 15:13:13 2005 -0700" >expect.out &&
: >expect.err &&
git log --format="%an+%ae+%ad" broken_email >actual.out 2>actual.err &&
Expand Down

0 comments on commit 0ceb753

Please sign in to comment.