X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FApp%2FRgit%2FCommand.pm;h=0a29f096fb86184d3b0a952d1e0d4f805d6340ed;hb=65e3405b02f27293a2f943b39d963f95d1f76192;hp=aa709c1140396e11980111711706db378b1a8e06;hpb=34eec9dcea44c01535ee6ab4593d98a724ce7e06;p=perl%2Fmodules%2Frgit.git diff --git a/lib/App/Rgit/Command.pm b/lib/App/Rgit/Command.pm index aa709c1..0a29f09 100644 --- a/lib/App/Rgit/Command.pm +++ b/lib/App/Rgit/Command.pm @@ -5,10 +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::Repository; +use App::Rgit::Utils qw/validate :codes/; =head1 NAME @@ -16,11 +15,11 @@ App::Rgit::Command - Base class for App::Rgit commands. =head1 VERSION -Version 0.02 +Version 0.03 =cut -our $VERSION = '0.02'; +our $VERSION = '0.03'; =head1 DESCRIPTION @@ -37,7 +36,7 @@ Creates a new command object for C<$cmd> that is bound to be called with argumen =cut my %commands; -__PACKAGE__->action($_ => 'Once') for qw/version help daemon init/, ' '; +__PACKAGE__->action($_ => 'Once') for qw/daemon gui help init version/, ' '; sub new { my ($class, %args) = &validate; @@ -52,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}, ); } @@ -78,10 +78,24 @@ 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