Code

fast-import: don't fail on omitted committer name
authorDmitry Ivankov <divanorama@gmail.com>
Thu, 11 Aug 2011 10:21:07 +0000 (16:21 +0600)
committerJunio C Hamano <gitster@pobox.com>
Thu, 11 Aug 2011 19:20:56 +0000 (12:20 -0700)
commit17fb00721b854b1c469e44ad709a9cad2128f11d
tree25ab30762332e2e47c3f90c76a68c962c38d5efe
parent4cedb78cb5eeb26d6dd47f866b51f061737616f2
fast-import: don't fail on omitted committer name

fast-import format declares 'committer_name SP' to be optional in
'committer_name SP LT email GT'. But for a (commit) object SP is
obligatory while zero length committer_name is ok. git-fsck checks
that SP is present, so fast-import must prepend it if the name SP
part is omitted. It doesn't do so and thus for "LT email GT" ident
it writes a bad object.

Name cannot contain LT or GT, ident always comes after SP in fast-import.
So if ident starts with LT reuse the SP as if a valid 'SP LT email GT'
ident was passed.

This fixes a ident parsing bug for a well-formed fast-import input.
Though the parsing is still loose and can accept a ill-formed input.

Signed-off-by: Dmitry Ivankov <divanorama@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
fast-import.c
t/t9300-fast-import.sh