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:
parent
1b67bef256
commit
bc93ceb7c5
37
git-svn.perl
37
git-svn.perl
@ -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});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user