X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FApp%2FRgit%2FConfig.pm;h=c59578f519511041d62b753c4fa52ee5047f75ef;hb=f39707f985871239ac340a2ac2b84f3c36d6d224;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..c59578f 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 root_repo git/; +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.02 + +=cut + +our $VERSION = '0.02'; =head1 DESCRIPTION @@ -33,16 +40,25 @@ 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(dir => $root, fake => 1); + return unless defined $r; $conf->SUPER::new( - root => $args{root}, - git => $args{git}, + root => $root, + root_repo => $r, + git => $args{git}, ); } =head2 C +=head2 C + =head2 C =head2 C