]> git.vpit.fr Git - perl/modules/rgit.git/blobdiff - lib/App/Rgit/Config.pm
This is 0.05
[perl/modules/rgit.git] / lib / App / Rgit / Config.pm
index c59578f519511041d62b753c4fa52ee5047f75ef..90afe3b35cf58b9147ef135710de14eaaca1a814 100644 (file)
@@ -7,10 +7,10 @@ use Carp qw/croak/;
 use Cwd qw/abs_path/;
 use File::Spec::Functions qw/file_name_is_absolute/;
 
-use Object::Tiny qw/root root_repo git/;
+use Object::Tiny qw/root git cwd_repo debug/;
 
 use App::Rgit::Repository;
-use App::Rgit::Utils qw/validate/;
+use App::Rgit::Utils qw/validate :levels/;
 
 =head1 NAME
 
@@ -18,11 +18,11 @@ App::Rgit::Config - Base class for App::Rgit configurations.
 
 =head1 VERSION
 
-Version 0.02
+Version 0.05
 
 =cut
 
-our $VERSION = '0.02';
+our $VERSION = '0.05';
 
 =head1 DESCRIPTION
 
@@ -46,23 +46,56 @@ sub new {
  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);
+ my $r = App::Rgit::Repository->new(fake => 1);
  return unless defined $r;
  $conf->SUPER::new(
-  root      => $root,
-  root_repo => $r,
-  git       => $args{git},
+  root     => $root,
+  git      => $args{git},
+  cwd_repo => $r,
+  debug    => defined $args{debug} ? int $args{debug} : WARN,
  );
 }
 
-=head2 C<root>
+=head2 C<info $msg>
+
+=head2 C<warn $msg>
+
+=head2 C<err $msg>
+
+=head2 C<crit $msg>
+
+Notifies a message C<$msg> of the corresponding level.
+
+=cut
+
+sub _notify {
+ my $self = shift;
+ my $level = shift;
+ if ($self->debug >= $level) {
+  print STDERR @_;
+  return 1;
+ }
+ return 0;
+}
+
+sub info { shift->_notify(INFO, @_) }
+
+sub warn { shift->_notify(WARN, @_) }
+
+sub err  { shift->_notify(ERR, @_) }
 
-=head2 C<root_repo>
+sub crit { shift->_notify(CRIT, @_) }
+
+=head2 C<root>
 
 =head2 C<git>
 
 =head2 C<repos>
 
+=head2 C<cwd_repo>
+
+=head2 C<debug>
+
 Accessors.
 
 =head1 SEE ALSO