Browse Source

cvsimport: use rev-parse to support packed refs

Previously, if refs were packed, git-cvsimport would assume
that particular refs did not exist. This could lead to, for
example, overwriting previous 'origin' commits that were
packed.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
maint
Jeff King 17 years ago committed by Junio C Hamano
parent
commit
9da0dabcd9
  1. 25
      git-cvsimport.perl
  2. 2
      t/t9600-cvsimport.sh

25
git-cvsimport.perl

@ -526,18 +526,12 @@ sub is_sha1 {
return $s =~ /^[a-f0-9]{40}$/; return $s =~ /^[a-f0-9]{40}$/;
} }


sub get_headref ($$) { sub get_headref ($) {
my $name = shift; my $name = shift;
my $git_dir = shift; my $r = `git rev-parse --verify '$name' 2>/dev/null`;

return undef unless $? == 0;
my $f = "$git_dir/$remote/$name"; chomp $r;
if (open(my $fh, $f)) { return $r;
chomp(my $r = <$fh>);
is_sha1($r) or die "Cannot get head id for $name ($r): $!";
return $r;
}
die "unable to open $f: $!" unless $! == POSIX::ENOENT;
return undef;
} }


-d $git_tree -d $git_tree
@ -697,7 +691,8 @@ my (@old,@new,@skipped,%ignorebranch);
$ignorebranch{'#CVSPS_NO_BRANCH'} = 1; $ignorebranch{'#CVSPS_NO_BRANCH'} = 1;


sub commit { sub commit {
if ($branch eq $opt_o && !$index{branch} && !get_headref($branch, $git_dir)) { if ($branch eq $opt_o && !$index{branch} &&
!get_headref("$remote/$branch")) {
# looks like an initial commit # looks like an initial commit
# use the index primed by git-init # use the index primed by git-init
$ENV{GIT_INDEX_FILE} = "$git_dir/index"; $ENV{GIT_INDEX_FILE} = "$git_dir/index";
@ -721,7 +716,7 @@ sub commit {
update_index(@old, @new); update_index(@old, @new);
@old = @new = (); @old = @new = ();
my $tree = write_tree(); my $tree = write_tree();
my $parent = get_headref($last_branch, $git_dir); my $parent = get_headref("$remote/$last_branch");
print "Parent ID " . ($parent ? $parent : "(empty)") . "\n" if $opt_v; print "Parent ID " . ($parent ? $parent : "(empty)") . "\n" if $opt_v;


my @commit_args; my @commit_args;
@ -732,7 +727,7 @@ sub commit {
foreach my $rx (@mergerx) { foreach my $rx (@mergerx) {
next unless $logmsg =~ $rx && $1; next unless $logmsg =~ $rx && $1;
my $mparent = $1 eq 'HEAD' ? $opt_o : $1; my $mparent = $1 eq 'HEAD' ? $opt_o : $1;
if (my $sha1 = get_headref($mparent, $git_dir)) { if (my $sha1 = get_headref("$remote/$mparent")) {
push @commit_args, '-p', $mparent; push @commit_args, '-p', $mparent;
print "Merge parent branch: $mparent\n" if $opt_v; print "Merge parent branch: $mparent\n" if $opt_v;
} }

2
t/t9600-cvsimport.sh

@ -57,6 +57,8 @@ test_expect_success 'import a trivial module' '


' '


test_expect_success 'pack refs' 'cd module-git && git gc && cd ..'

test_expect_success 'update cvs module' ' test_expect_success 'update cvs module' '


cd module-cvs && cd module-cvs &&

Loading…
Cancel
Save