[tor-commits] [builders/rbm] branch master updated: Bug 40038: Fix archiving of nested git submodules
gitolite role
git at cupani.torproject.org
Fri Apr 29 11:08:50 UTC 2022
This is an automated email from the git hooks/post-receive script.
gk pushed a commit to branch master
in repository builders/rbm.
The following commit(s) were added to refs/heads/master by this push:
new 86f77f6 Bug 40038: Fix archiving of nested git submodules
86f77f6 is described below
commit 86f77f63259a030315e0c20e80fa02ed3ab2688c
Author: Nicolas Vigier <boklm at torproject.org>
AuthorDate: Mon Apr 25 12:30:25 2022 +0200
Bug 40038: Fix archiving of nested git submodules
---
lib/RBM.pm | 34 ++++++++++++++++++----------------
1 file changed, 18 insertions(+), 16 deletions(-)
diff --git a/lib/RBM.pm b/lib/RBM.pm
index 8387fa3..24c6d44 100644
--- a/lib/RBM.pm
+++ b/lib/RBM.pm
@@ -478,6 +478,19 @@ sub run_script {
return @res == 1 ? $res[0] : @res;
}
+sub git_submodule_init_sync_update {
+ foreach my $action (
+ ['init'],
+ ['sync', '--recursive'],
+ ['update', '--recursive']
+ ) {
+ my ($stdout, $stderr, $success, $exit_code) =
+ capture_exec('git', 'submodule', @$action);
+ exit_error "Error running git submodule " . join(' ', @$action) . "\n$stderr"
+ unless $success;
+ }
+}
+
sub execute {
my ($project, $cmd, $options) = @_;
CORE::state %cache;
@@ -492,14 +505,8 @@ sub execute {
my ($stdout, $stderr, $success, $exit_code)
= capture_exec('git', 'checkout', $git_hash);
exit_error "Cannot checkout $git_hash:\n$stderr" unless $success;
- if (project_config($project, 'git_submodule', $options)) {
- foreach my $action (qw(init sync update)) {
- ($stdout, $stderr, $success, $exit_code)
- = capture_exec('git', 'submodule', $action);
- exit_error "Error running git submodule $action\n$stderr"
- unless $success;
- }
- }
+ git_submodule_init_sync_update()
+ if project_config($project, 'git_submodule', $options);
} elsif (project_config($project, 'hg_url', $options)) {
my $hg_hash = project_config($project, 'hg_hash', $options)
|| exit_error "No hg_hash specified for project $project";
@@ -574,15 +581,10 @@ sub maketar {
my ($stdout, $stderr, $success, $exit_code)
= capture_exec('git', 'checkout', $commit_hash);
exit_error "Cannot checkout $commit_hash: $stderr" unless $success;
- foreach my $action (qw(init sync update)) {
- ($stdout, $stderr, $success, $exit_code)
- = capture_exec('git', 'submodule', $action);
- exit_error "Error running git submodule $action\n$stderr"
- unless $success;
- }
+ git_submodule_init_sync_update();
($stdout, $stderr, $success, $exit_code)
- = capture_exec('git', 'submodule', 'foreach',
- "git archive --prefix=$project-$version/\$path/"
+ = capture_exec('git', 'submodule', 'foreach', '--recursive',
+ "git archive --prefix=$project-$version/\$displaypath/"
. " --output=$tmpdir/submodule.tar \$sha1;"
. "tar -Af \"$dest_dir/$tar_file\" $tmpdir/submodule.tar");
exit_error 'Error running git archive on submodules.' unless $success;
--
To stop receiving notification emails like this one, please contact
the administrator of this repository.
More information about the tor-commits
mailing list