X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FApp%2FRgit%2FCommand.pm;h=203041439d6e175db61a16127720b32975e917a4;hb=3a19229d25523e535c5a79343d4a4d80e153e389;hp=7410be77977afa88b94b165defe775c3b2b7982c;hpb=f34c972acf43aff431228979855d39fbd7c52faf;p=perl%2Fmodules%2Frgit.git diff --git a/lib/App/Rgit/Command.pm b/lib/App/Rgit/Command.pm index 7410be7..2030414 100644 --- a/lib/App/Rgit/Command.pm +++ b/lib/App/Rgit/Command.pm @@ -44,17 +44,19 @@ sub new { my $cmd = $args{cmd}; $cmd = ' ' unless defined $cmd; my $action = $class->action($cmd); - croak "Command $cmd shouldn't be executed as an $action" - unless $class eq __PACKAGE__ or $class->isa($action); - my @repos = grep $_->isa('App::Rgit::Repository'), - ref $args{repos} eq 'ARRAY' ? @{$args{repos}} : $args{repos}; + if ($class eq __PACKAGE__) { + $class = $action; + } else { + croak "Command $cmd should be executed as a $action" + unless $class->isa($action); + } eval "require $action; 1" or croak "Couldn't load $action: $@"; my $r = App::Rgit::Repository->new(fake => 1); return unless defined $r; - $action->SUPER::new( + $class->SUPER::new( cmd => $cmd, args => $args{args} || [ ], - repos => \@repos, + repos => $args{repos}, cwd_as_repo => $r, ); } @@ -68,9 +70,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}