use warnings;
use Cwd qw/cwd abs_path/;
-use File::Spec::Functions qw/catdir splitdir abs2rel file_name_is_absolute/;
+use File::Spec::Functions qw/canonpath catdir splitdir abs2rel file_name_is_absolute/;
use POSIX qw/WIFEXITED WEXITSTATUS WIFSIGNALED WTERMSIG SIGINT SIGQUIT/;
-use Object::Tiny qw/fake repo bare name work/;
-
-use App::Rgit::Utils qw/validate/;
+BEGIN {
+ no warnings 'redefine';
+ *WIFEXITED = sub { 1 } unless eval { WIFEXITED(0); 1 };
+ *WEXITSTATUS = sub { shift() >> 8 } unless eval { WEXITSTATUS(0); 1 };
+ *WIFSIGNALED = sub { shift() & 127 } unless eval { WIFSIGNALED(0); 1 };
+}
=head1 NAME
=head1 VERSION
-Version 0.04
+Version 0.06
=cut
-our $VERSION = '0.04';
+our $VERSION = '0.06';
=head1 DESCRIPTION
=cut
sub new {
- my ($class, %args) = &validate;
+ my $class = shift;
+ $class = ref $class || $class;
+
+ my %args = @_;
+
my $dir = $args{dir};
- $dir = abs_path $dir if defined $dir and not file_name_is_absolute $dir;
- $dir = cwd unless defined $dir;
+ $dir = abs_path $dir if defined $dir and not file_name_is_absolute $dir;
+ $dir = cwd unless defined $dir;
+ $dir = canonpath $dir;
+
my ($repo, $bare, $name, $work);
if ($args{fake}) {
$repo = $work = $dir;
- } else {
- my @tries = ($dir);
+ } else {
+ return unless -d $dir
+ and -d "$dir/refs"
+ and -d "$dir/objects"
+ and -e "$dir/HEAD";
+
my @chunks = splitdir $dir;
- my $last = pop @chunks;
- push @tries, "$dir.git" unless $last =~ /\.git$/;
- push @tries, catdir($dir, '.git') unless $last eq '.git';
- for (@tries) {
- if (-d $_ && -d "$_/refs" and -d "$_/objects" and -e "$_/HEAD") {
- $repo = $_;
- last;
- }
- }
- return unless defined $repo;
- @chunks = splitdir $repo;
- $last = pop @chunks;
+ my $last = pop @chunks;
+ return unless defined $last;
+
if ($last eq '.git') {
$bare = 0;
$name = $chunks[-1];
$work = catdir @chunks;
- } else {
+ } elsif ($last =~ /(.+)\.git$/) {
$bare = 1;
- ($name) = $last =~ /(.*)\.git$/;
- $work = $repo;
+ $name = $1;
+ $work = catdir @chunks, $last;
+ } else {
+ return;
}
+
+ $repo = $dir;
}
- $class->SUPER::new(
+
+ bless {
fake => !!$args{fake},
repo => $repo,
bare => $bare,
name => $name,
work => $work,
- );
+ }, $class;
}
=head2 C<chdir>
}
my %escapes = (
- '^' => sub { '^' },
+ '%' => sub { '%' },
'n' => sub { shift->name },
'g' => sub { _abs2rel(shift->repo, shift->root) },
'G' => sub { shift->repo },
return unless $conf->isa('App::Rgit::Config');
my @args = @_;
unless ($self->fake) {
- s/\^($e)/$escapes{$1}->($self, $conf)/eg for @args;
+ s/%($e)/$escapes{$1}->($self, $conf)/eg for @args;
}
+ unshift @args, $conf->git;
+ $conf->info('Executing "', join(' ', @args), '" into ', $self->work, "\n");
{
local $ENV{GIT_DIR} = $self->repo if exists $ENV{GIT_DIR};
local $ENV{GIT_EXEC_PATH} = $conf->git if exists $ENV{GIT_EXEC_PATH};
- system { $conf->git } $conf->git, @args;
+ system { $args[0] } @args;
}
if ($? == -1) {
$conf->crit("Failed to execute git: $!\n");
=head2 C<work>
-Accessors.
+Read-only accessors.
+
+=cut
+
+BEGIN {
+ eval "sub $_ { \$_[0]->{$_} }" for qw/fake repo bare name work/;
+}
=head1 SEE ALSO
=head1 AUTHOR
Vincent Pit, C<< <perl at profvince.com> >>, L<http://profvince.com>.
-
+
You can contact me by mail or on C<irc.perl.org> (vincent).
=head1 BUGS
=head1 COPYRIGHT & LICENSE
-Copyright 2008 Vincent Pit, all rights reserved.
+Copyright 2008-2009 Vincent Pit, all rights reserved.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.