X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FApp%2FRgit%2FCommand.pm;h=a73c9b4e688e2fb4e7cd2cd9505027327c6973fe;hb=6106b02a51da37eadcc29155ae4d51c07fff61ce;hp=3754d83363bfc3af04a5e703f456c700e3f92ba5;hpb=d2c0f4071b90c3b50696c5b7f9cc4ae341628f33;p=perl%2Fmodules%2Frgit.git diff --git a/lib/App/Rgit/Command.pm b/lib/App/Rgit/Command.pm index 3754d83..a73c9b4 100644 --- a/lib/App/Rgit/Command.pm +++ b/lib/App/Rgit/Command.pm @@ -5,7 +5,7 @@ use warnings; use Carp qw/croak/; -use Object::Tiny qw/cmd cwd_as_repo args repos/; +use Object::Tiny qw/cmd cwd_as_repo args/; use App::Rgit::Utils qw/validate/; use App::Rgit::Repository; @@ -16,11 +16,11 @@ App::Rgit::Command - Base class for App::Rgit commands. =head1 VERSION -Version 0.01 +Version 0.02 =cut -our $VERSION = '0.01'; +our $VERSION = '0.02'; =head1 DESCRIPTION @@ -30,9 +30,9 @@ This is an internal class to L. =head1 METHODS -=head2 C<< new cmd => $cmd, args => \@args, repos => \@repos >> +=head2 C<< new cmd => $cmd, args => \@args >> -Creates a new command object for C<$cmd> that will called for all repositories C<@repos> with arguments C<@args>. +Creates a new command object for C<$cmd> that is bound to be called with arguments C<@args>. =cut @@ -56,7 +56,6 @@ sub new { $class->SUPER::new( cmd => $cmd, args => $args{args} || [ ], - repos => $args{repos}, cwd_as_repo => $r, ); } @@ -70,9 +69,10 @@ Otherwise, returns the current class for C<$cmd>. sub action { my ($self, $cmd, $pkg) = @_; - $cmd = $self->cmd if !defined $cmd - and defined $self and $self->isa(__PACKAGE__); - return unless defined $cmd; + if (not defined $cmd) { + return unless defined $self and ref $self and $self->isa(__PACKAGE__); + $cmd = $self->cmd; + } unless (defined $pkg) { return __PACKAGE__ . '::Each' unless defined $commands{$cmd}; return $commands{$cmd} @@ -87,8 +87,6 @@ sub action { =head2 C -=head2 C - Accessors. =head2 C