X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FApp%2FRgit%2FCommand%2FEach.pm;h=b50e18040c60df1f202878cb5179dedef3f91e4d;hb=2e8121b94bf4847686087060a709fa3bb433f4ee;hp=ef384b76789af71aab74c27a25afdf7238e09d2b;hpb=0f55b91d632134b6077941fa223cd94378151373;p=perl%2Fmodules%2Frgit.git diff --git a/lib/App/Rgit/Command/Each.pm b/lib/App/Rgit/Command/Each.pm index ef384b7..b50e180 100644 --- a/lib/App/Rgit/Command/Each.pm +++ b/lib/App/Rgit/Command/Each.pm @@ -5,6 +5,7 @@ use warnings; use base qw/App::Rgit::Command/; +use App::Rgit::Guard; use App::Rgit::Utils qw/:codes/; =head1 NAME @@ -13,11 +14,11 @@ App::Rgit::Command::Each - Class for commands to execute for each repository. =head1 VERSION -Version 0.06 +Version 0.08 =cut -our $VERSION = '0.06'; +our $VERSION = '0.08'; =head1 DESCRIPTION @@ -38,12 +39,21 @@ It implements : sub run { my $self = shift; my $conf = shift; + my $status = 0; my $code; + + my $repos = 0; + my $guard = App::Rgit::Guard->new(sub { $conf->cwd_repo->chdir if $repos }); + for (@{$conf->repos}) { $_->chdir or next; + ++$repos; + ($status, my $signal) = $_->run($conf, @{$self->args}); + $code = $self->report($conf, $_, $status, $signal) unless defined $code; + last if $code & LAST; if ($code & REDO) { undef $code; # Don't save it, that would be very dumb @@ -51,7 +61,7 @@ sub run { } undef $code unless $code & SAVE; } - $conf->cwd_repo->chdir; + return wantarray ? ($status, $code) : $status; } @@ -69,7 +79,8 @@ You can contact me by mail or on C (vincent). =head1 BUGS -Please report any bugs or feature requests to C, or through the web interface at L. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes. +Please report any bugs or feature requests to C, or through the web interface at L. +I will be notified, and then you'll automatically be notified of progress on your bug as I make changes. =head1 SUPPORT