git-svn: un-break "git svn rebase" when log.abbrevCommit=true

Change git-svn to use git-rev-list(1) instead of git-log(1) since the
latter is porcelain that'll cause "git svn rebase" to fail completely
if log.abbrevCommit is set to true in the configuration.

Without this patch the code will fail to parse a SHA1, and then just
spew a bunch of "Use of uninitialized value $hash in string eq"
warnings at "if ($c && $c eq $hash) { ..." and never do anything
useful.

Signed-off-by: Ævar Arnfjörð Bjarmason <avarab@gmail.com>
Helped-by: Jonathan Nieder <jrnieder@gmail.com>
Acked-by: Eric Wong <normalperson@yhbt.net>
This commit is contained in:
Ævar Arnfjörð Bjarmason 2012-02-12 00:23:06 +00:00 committed by Eric Wong
parent b380e3a792
commit 83cf21f985

View File

@ -1878,8 +1878,7 @@ sub cmt_sha2rev_batch {
sub working_head_info { sub working_head_info {
my ($head, $refs) = @_; my ($head, $refs) = @_;
my @args = qw/log --no-color --no-decorate --first-parent my @args = qw/rev-list --first-parent --pretty=medium/;
--pretty=medium/;
my ($fh, $ctx) = command_output_pipe(@args, $head); my ($fh, $ctx) = command_output_pipe(@args, $head);
my $hash; my $hash;
my %max; my %max;