X-Git-Url: http://git.vpit.fr/?p=perl%2Fmodules%2Frgit.git;a=blobdiff_plain;f=lib%2FApp%2FRgit%2FCommand.pm;h=cf58e94b80e8f241a00ecdccb101221d80686a1a;hp=026c73a7047a2082bda40a3f52a9b81dc14a7381;hb=5578058510412fff726cb88b2c78075c43c59303;hpb=876aec5a45915d4fe3b4229787c3aa3e6b56f542 diff --git a/lib/App/Rgit/Command.pm b/lib/App/Rgit/Command.pm index 026c73a..cf58e94 100644 --- a/lib/App/Rgit/Command.pm +++ b/lib/App/Rgit/Command.pm @@ -5,9 +5,9 @@ use warnings; use Carp qw/croak/; -use Object::Tiny qw/cmd args/; +use Object::Tiny qw/cmd args policy/; -use App::Rgit::Utils qw/validate/; +use App::Rgit::Utils qw/validate :codes/; =head1 NAME @@ -51,8 +51,9 @@ sub new { } eval "require $action; 1" or croak "Couldn't load $action: $@"; $class->SUPER::new( - cmd => $cmd, - args => $args{args} || [ ], + cmd => $cmd, + args => $args{args} || [ ], + policy => $args{policy}, ); } @@ -77,17 +78,30 @@ sub action { $commands{$cmd} = $pkg; } +=head2 C + +=cut + +sub report { + my ($self) = @_; + my $cb = $self->policy; + return $_[3] ? LAST : NEXT unless $cb; + my $code = $cb->(@_); + return defined $code ? $code : NEXT; +} + =head2 C =head2 C +=head2 C + Accessors. =head2 C Runs the command with a L configuration object. -Stops as soon as one of the executed commands fails, and returns the corresponding exit code. -Returns zero when all went fine. +Handles back the code to return to the system and the last policy. Implemented in subclasses. =head1 SEE ALSO