[tor-commits] [builders/rbm] 02/02: Bug 40048: Add a hg_clone_subdir option

gitolite role git at cupani.torproject.org
Wed Nov 2 14:55:16 UTC 2022


This is an automated email from the git hooks/post-receive script.

boklm pushed a commit to branch main
in repository builders/rbm.

commit a6ccc103fe59f6b520777308af92bf98113e2c90
Author: Nicolas Vigier <boklm at torproject.org>
AuthorDate: Tue Nov 1 18:22:58 2022 +0100

    Bug 40048: Add a hg_clone_subdir option
---
 doc/rbm_config.asc       |  7 +++++++
 lib/RBM.pm               | 21 ++++++++++++++-------
 lib/RBM/DefaultConfig.pm |  1 +
 3 files changed, 22 insertions(+), 7 deletions(-)

diff --git a/doc/rbm_config.asc b/doc/rbm_config.asc
index dc045e2..226ccae 100644
--- a/doc/rbm_config.asc
+++ b/doc/rbm_config.asc
@@ -145,6 +145,13 @@ hg_clone_dir::
         The directory used to store clones of mercurial repositories.
         The default value is +hg_clones+.
 
+hg_clone_subdir::
+        If this option is set, the repository is cloned in a
+        subdirectory with that name. This is useful if a single project
+        requires clones of multiple mercurial repositories, for example
+        using a different +hg_url+ in each +targets+ or +steps+.
+        The default value is +.+, which means that no subdirectory is used.
+
 hg_opt::
         This option contains options that should be passed on the
         mercurial command line. This can for instance be useful if you
diff --git a/lib/RBM.pm b/lib/RBM.pm
index 86d9a9d..2209890 100644
--- a/lib/RBM.pm
+++ b/lib/RBM.pm
@@ -476,8 +476,8 @@ sub git_clone_fetch_chdir {
 }
 
 sub hg_need_fetch {
-    my ($project, $options) = @_;
-    return 0 if $config->{_rbm}{fetched_projects}{$project};
+    my ($project, $subdir, $options) = @_;
+    return 0 if $config->{_rbm}{hg_fetched_projects}{$project}{$subdir};
     my $fetch = project_config($project, 'fetch', $options);
     if ($fetch eq 'if_needed') {
         my $hg_hash = project_config($project, 'hg_hash', $options)
@@ -495,18 +495,25 @@ sub hg_clone_fetch_chdir {
                                 'hg_clone_dir', $options)));
     my $hg_url = shell_quote(project_config($project, 'hg_url', $options))
                 || exit_error "hg_url is undefined";
-    my $sq_project = shell_quote($project);
-    if (!chdir rbm_path("$clonedir/$project")) {
+    my $subdir = project_config($project, 'hg_clone_subdir', $options);
+    exit_error "hg_clone_subdir ($subdir) cannot be '..'" if $subdir eq '..';
+    exit_error "hg_clone_subdir ($subdir) cannot include / or \\"
+                if $subdir =~ m|[\\/]|;
+    my $destdir = $subdir eq '.' ? $project : "$project/$subdir";
+    my $sq_destdir = shell_quote($destdir);
+    if (!chdir rbm_path("$clonedir/$destdir")) {
         chdir $clonedir || exit_error "Can't enter directory $clonedir: $!";
-        if (system("$hg clone -q $hg_url $sq_project") != 0) {
+        mkdir $project if $subdir ne '.';
+        if (system("$hg clone -q $hg_url $sq_destdir") != 0) {
             exit_error "Error cloning $hg_url";
         }
-        chdir($project) || exit_error "Error entering $project directory";
+        chdir($destdir) || exit_error "Error entering $destdir directory";
     }
-    if (hg_need_fetch($project, $options)) {
+    if (hg_need_fetch($project, $subdir, $options)) {
         system("$hg pull -q $hg_url") == 0
                 || exit_error "Error pulling changes from $hg_url";
     }
+    $config->{_rbm}{hg_fetched_projects}{$project}{$subdir} = 1;
 }
 
 sub run_script {
diff --git a/lib/RBM/DefaultConfig.pm b/lib/RBM/DefaultConfig.pm
index b60d5c2..32072c4 100644
--- a/lib/RBM/DefaultConfig.pm
+++ b/lib/RBM/DefaultConfig.pm
@@ -116,6 +116,7 @@ our %default_config = (
     output_dir    => 'out',
     git_clone_dir => 'git_clones',
     hg_clone_dir  => 'hg_clones',
+    hg_clone_subdir  => '.',
     fetch         => 'if_needed',
     pkg_type      => 'build',
     build         => '[% INCLUDE build -%]',

-- 
To stop receiving notification emails like this one, please contact
the administrator of this repository.


More information about the tor-commits mailing list