No need for addtional variable.
[catagits/Gitalist.git] / lib / Gitalist / Git / CollectionOfRepositories / FromDirectoryRecursive.pm
CommitLineData
576d59a0 1use MooseX::Declare;
2
3class Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive
4 with Gitalist::Git::CollectionOfRepositories {
5 use MooseX::Types::Common::String qw/NonEmptySimpleStr/;
6 use MooseX::Types::Path::Class qw/Dir/;
7
8 has repo_dir => (
9 isa => Dir,
10 is => 'ro',
11 required => 1,
12 coerce => 1,
13 );
14
15 method BUILD {
16 # Make sure repo_dir is an absolute path so that
17 # ->contains() works correctly.
18 $self->repo_dir->resolve;
19 }
20
21 method _get_path_for_repository_name (NonEmptySimpleStr $name) {
e473ebf6 22 my $path = $self->repo_dir->subdir($name)->resolve;
23 die "Directory traversal prohibited"
24 unless $self->repo_dir->contains($path);
25 return $path;
576d59a0 26 }
27
28 ## Builders
29 method _build_repositories {
e473ebf6 30 my @ret;
31 $self->repo_dir->recurse(
32 callback => sub {
33 my ( $dir ) = @_;
34 if ( $dir->is_dir ) {
35 for my $repo ( @ret ) {
36 # no need to go further if parent is git dir
37 # never have a git repo in a git repo?
38 return if ( $repo->path->contains( $dir ) );
39 }
40 eval {
41 # slight hack since get_repo expects string
42 my @list = $dir->dir_list();
43 my $p = $self->get_repository($list[$#list]);
44 push @ret, $p;
45 };
46 }
47 return;
576d59a0 48 }
e473ebf6 49 );
50 return \@ret;
576d59a0 51 }
e473ebf6 52} # end class
576d59a0 53
54__END__
55
56=head1 NAME
57
58Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive - Model of recursive directories containing git repositories
59
60=head1 SYNOPSIS
61
62 my $repo = Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive->new( repo_dir => $Dir );
63 my $repository_list = $repo->repositories;
64 my $first_repository = $repository_list->[0];
65 my $named_repository = $repo->get_repository('Gitalist');
66
67=head1 DESCRIPTION
68
69This class provides a list of Repositories recursively found in the given directory.
70
71=head1 ATTRIBUTES
72
73=head2 repo_dir (C<Path::Class::Dir>)
74
75The filesystem root of the C<Repo>.
76
77=head1 SEE ALSO
78
79L<Gitalist::Git::CollectionOfRepositories>, L<Gitalist::Git::Repository>
80
81=head1 AUTHORS
82
83See L<Gitalist> for authors.
84
85=head1 LICENSE
86
87See L<Gitalist> for the license.
88
89=cut