From 4d57e0a8dab2139a631a21aab862487481548702 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Mon, 15 Apr 2024 22:32:59 +0200 Subject: Adding upstream version 2.23.7. Signed-off-by: Daniel Baumann --- lib/Devscripts/Salsa/rename_branch.pm | 47 +++++++++++++++++++++++++++++++++++ 1 file changed, 47 insertions(+) create mode 100644 lib/Devscripts/Salsa/rename_branch.pm (limited to 'lib/Devscripts/Salsa/rename_branch.pm') diff --git a/lib/Devscripts/Salsa/rename_branch.pm b/lib/Devscripts/Salsa/rename_branch.pm new file mode 100644 index 0000000..f3a0f1b --- /dev/null +++ b/lib/Devscripts/Salsa/rename_branch.pm @@ -0,0 +1,47 @@ +package Devscripts::Salsa::rename_branch; + +use strict; +use Devscripts::Output; +use Moo::Role; + +with "Devscripts::Salsa::Repo"; + +our $prompt = 1; + +sub rename_branch { + my ($self, @reponames) = @_; + my $res = 0; + my @repos = $self->get_repo($prompt, @reponames); + return @repos unless (ref $repos[0]); # get_repo returns 1 when fails + foreach (@repos) { + my $id = $_->[0]; + my $str = $_->[1]; + if (!$id) { + ds_warn "Branch rename has failed for $str (missing ID)\n"; + return 1; + } + ds_verbose "Configuring $str"; + my $project = $self->api->project($id); + eval { + $self->api->create_branch( + $id, + { + ref => $self->config->source_branch, + branch => $self->config->dest_branch, + }); + $self->api->delete_branch($id, $self->config->source_branch); + }; + if ($@) { + ds_warn "Branch rename has failed for $str\n"; + ds_verbose $@; + unless ($self->config->no_fail) { + ds_verbose "Use --no-fail to continue"; + return 1; + } + next; + } + } + return $res; +} + +1; -- cgit v1.2.3