use Carp qw/croak/;
-use Object::Tiny qw/cmd cwd_as_repo args repos/;
+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
=head1 VERSION
-Version 0.02
+Version 0.05
=cut
-our $VERSION = '0.02';
+our $VERSION = '0.05';
=head1 DESCRIPTION
=head1 METHODS
-=head2 C<< new cmd => $cmd, args => \@args, repos => \@repos >>
+=head2 C<< new cmd => $cmd, args => \@args >>
-Creates a new command object for C<$cmd> that will called for all repositories C<@repos> with arguments C<@args>.
+Creates a new command object for C<$cmd> that is bound to be called with arguments C<@args>.
=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;
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} || [ ],
- repos => $args{repos},
- cwd_as_repo => $r,
+ cmd => $cmd,
+ args => $args{args} || [ ],
+ policy => $args{policy},
);
}
$commands{$cmd} = $pkg;
}
-=head2 C<cmd>
+=head2 C<report $conf, $repo, $status>
+
+=cut
-=head2 C<cwd_as_repo>
+sub report {
+ my ($self) = @_;
+ my $cb = $self->policy;
+ return $_[3] ? LAST : NEXT unless $cb;
+ my $code = $cb->(@_);
+ return defined $code ? $code : NEXT;
+}
+
+=head2 C<cmd>
=head2 C<args>
-=head2 C<repos>
+=head2 C<policy>
Accessors.
=head2 C<run $conf>
Runs the command with a L<App::Rgit::Config> 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