git-svn: Simplify calculation of GIT_DIR

Since git-rev-parse already checks for the $GIT_DIR environment
variable and that it returns an actual git repository, there is no
need to repeat the checks again here.

This also fixes a problem where git-svn did not work in cases where
.git was a file with a gitdir: link.

[ew: squashed test case,
 delay setting GIT_DIR until after `git rev-parse --cdup` to fix t9101,
 (thanks to Junio)]

Signed-off-by: Barry Wardell <barry.wardell@gmail.com>
Signed-off-by: Eric Wong <normalperson@yhbt.net>
This commit is contained in:
Barry Wardell 2013-01-21 01:22:02 +00:00 committed by Eric Wong
parent 1b67bef256
commit bc93ceb7c5
2 changed files with 22 additions and 23 deletions

View File

@ -61,8 +61,6 @@ my $cmd_dir_prefix = eval {
command_oneline([qw/rev-parse --show-prefix/], STDERR => 0) command_oneline([qw/rev-parse --show-prefix/], STDERR => 0)
} || ''; } || '';
my $git_dir_user_set = 1 if defined $ENV{GIT_DIR};
$ENV{GIT_DIR} ||= '.git';
$Git::SVN::Ra::_log_window_size = 100; $Git::SVN::Ra::_log_window_size = 100;
if (! exists $ENV{SVN_SSH} && exists $ENV{GIT_SSH}) { if (! exists $ENV{SVN_SSH} && exists $ENV{GIT_SSH}) {
@ -327,27 +325,20 @@ for (my $i = 0; $i < @ARGV; $i++) {
}; };
# make sure we're always running at the top-level working directory # make sure we're always running at the top-level working directory
unless ($cmd && $cmd =~ /(?:clone|init|multi-init)$/) { if ($cmd && $cmd =~ /(?:clone|init|multi-init)$/) {
unless (-d $ENV{GIT_DIR}) { $ENV{GIT_DIR} ||= ".git";
if ($git_dir_user_set) { } else {
die "GIT_DIR=$ENV{GIT_DIR} explicitly set, ", my ($git_dir, $cdup);
"but it is not a directory\n"; git_cmd_try {
} $git_dir = command_oneline([qw/rev-parse --git-dir/]);
my $git_dir = delete $ENV{GIT_DIR}; } "Unable to find .git directory\n";
my $cdup = undef; git_cmd_try {
git_cmd_try { $cdup = command_oneline(qw/rev-parse --show-cdup/);
$cdup = command_oneline(qw/rev-parse --show-cdup/); chomp $cdup if ($cdup);
$git_dir = '.' unless ($cdup); $cdup = "." unless ($cdup && length $cdup);
chomp $cdup if ($cdup); } "Already at toplevel, but $git_dir not found\n";
$cdup = "." unless ($cdup && length $cdup); $ENV{GIT_DIR} = $git_dir;
} "Already at toplevel, but $git_dir not found\n"; chdir $cdup or die "Unable to chdir up to '$cdup'\n";
chdir $cdup or die "Unable to chdir up to '$cdup'\n";
unless (-d $git_dir) {
die "$git_dir still not found after going to ",
"'$cdup'\n";
}
$ENV{GIT_DIR} = $git_dir;
}
$_repository = Git->repository(Repository => $ENV{GIT_DIR}); $_repository = Git->repository(Repository => $ENV{GIT_DIR});
} }

View File

@ -306,5 +306,13 @@ test_expect_success 'git-svn works in a bare repository' '
git svn fetch ) && git svn fetch ) &&
rm -rf bare-repo rm -rf bare-repo
' '
test_expect_success 'git-svn works in in a repository with a gitdir: link' '
mkdir worktree gitdir &&
( cd worktree &&
git svn init "$svnrepo" &&
git init --separate-git-dir ../gitdir &&
git svn fetch ) &&
rm -rf worktree gitdir
'
test_done test_done