X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FApp%2FRgit.pm;h=ea9df10da2367299fe37c7ad995f43e9db3b69b1;hb=1c5bf56c6f80e4cd818c341b34ba3410f34ed514;hp=91999e2b4ee565f4da283f5906b5ce18ca709632;hpb=c86be01d791b2919e100f9a7357597dfdfe1e273;p=perl%2Fmodules%2Frgit.git diff --git a/lib/App/Rgit.pm b/lib/App/Rgit.pm index 91999e2..ea9df10 100644 --- a/lib/App/Rgit.pm +++ b/lib/App/Rgit.pm @@ -3,11 +3,8 @@ package App::Rgit; use strict; use warnings; -use Object::Tiny qw/config command/; - use App::Rgit::Command; use App::Rgit::Config; -use App::Rgit::Utils qw/validate/; =head1 NAME @@ -15,11 +12,11 @@ App::Rgit - Backend that supports the rgit utility. =head1 VERSION -Version 0.05 +Version 0.06 =cut -our $VERSION = '0.05'; +our $VERSION = '0.06'; =head1 DESCRIPTION @@ -36,23 +33,29 @@ Creates a new L object that's bound to execute the command C<$cmd> on =cut sub new { - my ($class, %args) = &validate; + my $class = shift; + $class = ref $class || $class; + + my %args = @_; + my $config = App::Rgit::Config->new( root => $args{root}, git => $args{git}, debug => $args{debug}, ); return unless defined $config; + my $command = App::Rgit::Command->new( cmd => $args{cmd}, args => $args{args}, policy => $args{policy}, ); return unless defined $command; - $class->SUPER::new( + + bless { config => $config, command => $command, - ); + }, $class; } =head2 C @@ -63,6 +66,7 @@ Actually run the commands. sub run { my $self = shift; + $self->command->run($self->config); } @@ -70,7 +74,13 @@ sub run { =head2 C -Accessors. +Read-only accessors. + +=cut + +BEGIN { + eval "sub $_ { \$_[0]->{$_} }" for qw/config command/; +} =head1 SEE ALSO @@ -79,7 +89,7 @@ L. =head1 AUTHOR Vincent Pit, C<< >>, L. - + You can contact me by mail or on C (vincent). =head1 BUGS