forked from lix-project/hydra
Allow use of a single Git clone for several branches.
This reinstates commit 53329ecc61
, but
uses "git pull --all", instead of "git fetch --all", so that local
tracking branches get updated too.
This commit is contained in:
parent
ed23a6e6d3
commit
6e62d9b7b5
1 changed files with 6 additions and 2 deletions
|
@ -323,7 +323,7 @@ sub fetchInputGit {
|
||||||
my $storePath;
|
my $storePath;
|
||||||
|
|
||||||
mkpath(scmPath);
|
mkpath(scmPath);
|
||||||
my $clonePath = scmPath . "/" . sha256_hex($uri.$branch);
|
my $clonePath = scmPath . "/" . sha256_hex($uri);
|
||||||
|
|
||||||
my $stdout; my $stderr;
|
my $stdout; my $stderr;
|
||||||
if (! -d $clonePath) {
|
if (! -d $clonePath) {
|
||||||
|
@ -335,7 +335,7 @@ sub fetchInputGit {
|
||||||
# git pull + check rev
|
# git pull + check rev
|
||||||
chdir $clonePath or die $!; # !!! urgh, shouldn't do a chdir
|
chdir $clonePath or die $!; # !!! urgh, shouldn't do a chdir
|
||||||
(my $res, $stdout, $stderr) = captureStdoutStderr(600,
|
(my $res, $stdout, $stderr) = captureStdoutStderr(600,
|
||||||
("git", "pull"));
|
("git", "pull", "--all"));
|
||||||
die "Error pulling latest change git repo at `$uri':\n$stderr" unless $res;
|
die "Error pulling latest change git repo at `$uri':\n$stderr" unless $res;
|
||||||
|
|
||||||
(my $res1, $stdout, $stderr) = captureStdoutStderr(600,
|
(my $res1, $stdout, $stderr) = captureStdoutStderr(600,
|
||||||
|
@ -343,6 +343,10 @@ sub fetchInputGit {
|
||||||
|
|
||||||
die "Cannot get head revision of Git branch '$branch' at `$uri':\n$stderr" unless $res1 ;
|
die "Cannot get head revision of Git branch '$branch' at `$uri':\n$stderr" unless $res1 ;
|
||||||
|
|
||||||
|
# Take the first commit ID returned by `ls-remote'. The
|
||||||
|
# assumption is that `ls-remote' returned both `refs/heads/BRANCH'
|
||||||
|
# and `refs/remotes/origin/BRANCH', and that both point at the
|
||||||
|
# same commit.
|
||||||
my ($first) = split /\n/, $stdout;
|
my ($first) = split /\n/, $stdout;
|
||||||
(my $revision, my $ref) = split ' ', $first;
|
(my $revision, my $ref) = split ' ', $first;
|
||||||
die unless $revision =~ /^[0-9a-fA-F]+$/;
|
die unless $revision =~ /^[0-9a-fA-F]+$/;
|
||||||
|
|
Loading…
Reference in a new issue