X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FApp%2FRgit%2FCommand.pm;h=348b8c40aab70ef4c659ba8167ca287222b95807;hb=1c5bf56c6f80e4cd818c341b34ba3410f34ed514;hp=a73c9b4e688e2fb4e7cd2cd9505027327c6973fe;hpb=6106b02a51da37eadcc29155ae4d51c07fff61ce;p=perl%2Fmodules%2Frgit.git diff --git a/lib/App/Rgit/Command.pm b/lib/App/Rgit/Command.pm index a73c9b4..348b8c4 100644 --- a/lib/App/Rgit/Command.pm +++ b/lib/App/Rgit/Command.pm @@ -5,10 +5,7 @@ use warnings; use Carp qw/croak/; -use Object::Tiny qw/cmd cwd_as_repo args/; - -use App::Rgit::Utils qw/validate/; -use App::Rgit::Repository; +use App::Rgit::Utils qw/:codes/; =head1 NAME @@ -16,11 +13,11 @@ App::Rgit::Command - Base class for App::Rgit commands. =head1 VERSION -Version 0.02 +Version 0.06 =cut -our $VERSION = '0.02'; +our $VERSION = '0.06'; =head1 DESCRIPTION @@ -37,27 +34,32 @@ 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; + my $class = shift; + $class = ref $class || $class; + + my %args = @_; + my $cmd = $args{cmd}; $cmd = ' ' unless defined $cmd; + my $action = $class->action($cmd); + 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; - $class->SUPER::new( - cmd => $cmd, - args => $args{args} || [ ], - cwd_as_repo => $r, - ); + bless { + cmd => $cmd, + args => $args{args} || [ ], + policy => $args{policy}, + }, $class; } =head2 C<< action $cmd [ => $pkg ] >> @@ -81,19 +83,39 @@ sub action { $commands{$cmd} = $pkg; } -=head2 C +=head2 C + +Reports that the execution of the command in C<$repo> exited with C<$status> to the current command's policy. +Returns what policy C method returned, which should be one of the policy codes listed in C. + +=cut + +sub report { + my ($self) = @_; -=head2 C + my $code = $self->policy->report(@_); + + return defined $code ? $code : NEXT; +} + +=head2 C =head2 C -Accessors. +=head2 C + +Read-only accessors. + +=cut + +BEGIN { + eval "sub $_ { \$_[0]->{$_} }" for qw/cmd args policy/; +} =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 @@ -103,7 +125,7 @@ L. =head1 AUTHOR Vincent Pit, C<< >>, L. - + You can contact me by mail or on C (vincent). =head1 BUGS @@ -118,7 +140,7 @@ You can find documentation for this module with the perldoc command. =head1 COPYRIGHT & LICENSE -Copyright 2008 Vincent Pit, all rights reserved. +Copyright 2008-2009 Vincent Pit, all rights reserved. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.