X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FApp%2FRgit%2FConfig.pm;h=d585374fa7a923bbae2c3830cefb567110954a92;hb=67e585ffae69ce0c350a920658738d7864b1d54a;hp=20ef2234d77f0c58b00ea268cc4f71776b619079;hpb=19bee8f647bfe6c94c5cb3cf6a60d7a43cbca222;p=perl%2Fmodules%2Frgit.git diff --git a/lib/App/Rgit/Config.pm b/lib/App/Rgit/Config.pm index 20ef223..d585374 100644 --- a/lib/App/Rgit/Config.pm +++ b/lib/App/Rgit/Config.pm @@ -4,9 +4,12 @@ use strict; use warnings; use Carp qw/croak/; +use Cwd qw/abs_path/; +use File::Spec::Functions qw/file_name_is_absolute/; -use Object::Tiny qw/root git/; +use Object::Tiny qw/root git cwd_repo/; +use App::Rgit::Repository; use App::Rgit::Utils qw/validate/; =head1 NAME @@ -15,7 +18,11 @@ App::Rgit::Config - Base class for App::Rgit configurations. =head1 VERSION -Version 0.01 +Version 0.03 + +=cut + +our $VERSION = '0.03'; =head1 DESCRIPTION @@ -33,11 +40,18 @@ Creates a new configuration object based on the root directory C<$root> and usin sub new { my ($class, %args) = &validate; + my $root = $args{root}; + return unless defined $root and -d $root; + $root = abs_path $root unless file_name_is_absolute $root; + return unless defined $args{git} and -x $args{git}; my $conf = 'App::Rgit::Config::Default'; eval "require $conf; 1" or croak "Couldn't load $conf: $@"; + my $r = App::Rgit::Repository->new(fake => 1); + return unless defined $r; $conf->SUPER::new( - root => $args{root}, - git => $args{git}, + root => $root, + git => $args{git}, + cwd_repo => $r, ); } @@ -47,6 +61,8 @@ sub new { =head2 C +=head2 C + Accessors. =head1 SEE ALSO