X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FApp%2FRgit%2FCommand.pm;h=c43cc6c5c9e7cbe21a3a4622acd5e8c6b2163bbd;hb=76ba389e3711e8f254aea83f9b3b7b221c0517a8;hp=e04e9f574167d0b570943d5133085efcd0cfe406;hpb=787cc59d827d22afa8a3100daa42e5b9df3fe50d;p=perl%2Fmodules%2Frgit.git diff --git a/lib/App/Rgit/Command.pm b/lib/App/Rgit/Command.pm index e04e9f5..c43cc6c 100644 --- a/lib/App/Rgit/Command.pm +++ b/lib/App/Rgit/Command.pm @@ -5,8 +5,6 @@ use warnings; use Carp qw/croak/; -use Object::Tiny qw/cmd args policy/; - use App::Rgit::Utils qw/validate :codes/; =head1 NAME @@ -50,11 +48,11 @@ sub new { unless $class->isa($action); } eval "require $action; 1" or croak "Couldn't load $action: $@"; - $class->SUPER::new( + bless { cmd => $cmd, args => $args{args} || [ ], policy => $args{policy}, - ); + }, $class; } =head2 C<< action $cmd [ => $pkg ] >> @@ -81,15 +79,15 @@ sub action { =head2 C Reports that the execution of the command in C<$repo> exited with C<$status> to the current command's policy. -Returns what the policy callback returned, which should be one of the policy codes listed in C. +Returns what policy C method returned, which should be one of the policy codes listed in C. =cut sub report { my ($self) = @_; - my $cb = $self->policy; - return $_[3] ? LAST : NEXT unless $cb; - my $code = $cb->(@_); + + my $code = $self->policy->report(@_); + return defined $code ? $code : NEXT; } @@ -99,7 +97,13 @@ sub report { =head2 C -Accessors. +Read-only accessors. + +=cut + +BEGIN { + eval "sub $_ { \$_[0]->{$_} }" for qw/cmd args policy/; +} =head2 C