Get sane debugging info for the setup of everything
[catagits/Gitalist.git] / lib / Gitalist / Git / CollectionOfRepositories / FromDirectoryRecursive.pm
1 use MooseX::Declare;
2
3 class Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive {
4     use MooseX::Types::Common::String qw/NonEmptySimpleStr/;
5     use MooseX::Types::Path::Class qw/Dir/;
6
7     use Moose::Autobox;
8     use List::Util 'first';
9
10     has repo_dir => (
11         isa => Dir,
12         is => 'ro',
13         required => 1,
14         coerce => 1,
15     );
16
17     method debug_string { 'repository directory ' . $self->repo_dir }
18
19     method BUILD {
20       # Make sure repo_dir is an absolute path so that ->contains() works correctly.
21       $self->repo_dir->resolve;
22     }
23
24     method _find_repos(Dir $dir) {
25       return map {
26         $self->_is_git_repo($_) ? $_ : $self->_find_repos($_)
27       } grep $_->is_dir, $dir->children;
28     }
29
30     method _get_repo_from_name (NonEmptySimpleStr $name) {
31       my $repo = first { $_->name eq $name } $self->repositories->flatten
32         or return;
33       return $repo;
34     }
35
36     method _get_repo_name (NonEmptySimpleStr $name) {
37         # strip off the repo_dir part from a path
38         return Path::Class::Dir->new($name)->relative($self->repo_dir)->stringify;
39     }
40
41     ## Builders
42     method _build_repositories {
43       return [
44         map { Gitalist::Git::Repository->new($_, $self->_get_repo_name("$_")) } $self->_find_repos( $self->repo_dir )
45       ];
46     }
47     with 'Gitalist::Git::CollectionOfRepositories';
48 }                         # end class
49
50 __END__
51
52 =head1 NAME
53
54 Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive - Model of recursive directories containing git repositories
55
56 =head1 SYNOPSIS
57
58     my $repo = Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive->new( repo_dir => $Dir );
59     my $repository_list = $repo->repositories;
60     my $first_repository = $repository_list->[0];
61     my $named_repository = $repo->get_repository('Gitalist');
62
63 =head1 DESCRIPTION
64
65 This class provides a list of Repositories recursively found in the given directory.
66
67 =head1 ATTRIBUTES
68
69 =head2 repo_dir (C<Path::Class::Dir>)
70
71 The filesystem root of the C<Repo>.
72
73 =head1 SEE ALSO
74
75 L<Gitalist::Git::CollectionOfRepositories>, L<Gitalist::Git::Repository>
76
77 =head1 AUTHORS
78
79 See L<Gitalist> for authors.
80
81 =head1 LICENSE
82
83 See L<Gitalist> for the license.
84
85 =cut