diff options
| author | Frank Lichtenheld <flichtenheld@astaro.com> | 2009-05-07 15:41:27 +0200 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2009-05-09 08:25:55 -0700 | 
| commit | da159c7759418bb14af655968dfa7a98bdcb8661 (patch) | |
| tree | b5d108f10e1c6d05988693e8c0f3c319f8c9a121 | |
| parent | f01f1099f40f24fe6f7802185340a6fa3a3d4f35 (diff) | |
| download | git-da159c7759418bb14af655968dfa7a98bdcb8661.tar.gz | |
Git.pm: Set GIT_WORK_TREE if we set GIT_DIR
Otherwise git will use the current directory as work tree which will
lead to unexpected results if we operate in sub directory of the
work tree.
Signed-off-by: Frank Lichtenheld <flichtenheld@astaro.com>
Acked-by: Petr Baudis <pasky@suse.cz>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
| -rw-r--r-- | perl/Git.pm | 2 | ||||
| -rwxr-xr-x | t/t9700-perl-git.sh | 4 | ||||
| -rwxr-xr-x | t/t9700/test.pl | 13 | 
3 files changed, 19 insertions, 0 deletions
| diff --git a/perl/Git.pm b/perl/Git.pm index 291ff5b53c..4313db75b5 100644 --- a/perl/Git.pm +++ b/perl/Git.pm @@ -1280,6 +1280,8 @@ sub _cmd_exec {  	my ($self, @args) = @_;  	if ($self) {  		$self->repo_path() and $ENV{'GIT_DIR'} = $self->repo_path(); +		$self->repo_path() and $self->wc_path() +			and $ENV{'GIT_WORK_TREE'} = $self->wc_path();  		$self->wc_path() and chdir($self->wc_path());  		$self->wc_subdir() and chdir($self->wc_subdir());  	} diff --git a/t/t9700-perl-git.sh b/t/t9700-perl-git.sh index b4ca244626..4eb7d3f7f0 100755 --- a/t/t9700-perl-git.sh +++ b/t/t9700-perl-git.sh @@ -29,6 +29,10 @@ test_expect_success \       git add . &&       git commit -m "first commit" && +     echo "new file in subdir 2" > directory2/file2 && +     git add . && +     git commit -m "commit in directory2" && +       echo "changed file 1" > file1 &&       git commit -a -m "second commit" && diff --git a/t/t9700/test.pl b/t/t9700/test.pl index 697daf3ffd..d9b29eab22 100755 --- a/t/t9700/test.pl +++ b/t/t9700/test.pl @@ -98,3 +98,16 @@ TODO: {  	todo_skip 'config after wc_chdir', 1;  	is($r->config("color.string"), "value", "config after wc_chdir");  } + +# Object generation in sub directory +chdir("directory2"); +my $r2 = Git->repository(); +is($r2->repo_path, $abs_repo_dir . "/.git", "repo_path (2)"); +is($r2->wc_path, $abs_repo_dir . "/", "wc_path (2)"); +is($r2->wc_subdir, "directory2/", "wc_subdir initial (2)"); + +# commands in sub directory +my $last_commit = $r2->command_oneline(qw(rev-parse --verify HEAD)); +like($last_commit, qr/^[0-9a-fA-F]{40}$/, 'rev-parse returned hash'); +my $dir_commit = $r2->command_oneline('log', '-n1', '--pretty=format:%H', '.'); +isnt($last_commit, $dir_commit, 'log . does not show last commit'); | 
