3 class 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/;
8 use MooseX::Types::Common::String qw/NonEmptySimpleStr/;
9 use MooseX::Types::Path::Class qw/Dir/;
12 use List::Util 'first';
22 # Make sure repo_dir is an absolute path so that
23 # ->contains() works correctly.
24 $self->repo_dir->resolve;
27 method _find_repos(Dir $dir) {
29 $self->_is_git_repo($_) ? $_ : $self->_find_repos($_)
30 } grep $_->is_dir, $dir->children;
33 method _get_path_for_repository_name (NonEmptySimpleStr $name) {
34 my $repo = first { $_->name eq $name } $self->repositories->flatten
40 method _build_repositories {
42 map Gitalist::Git::Repository->new($_), $self->_find_repos( $self->repo_dir )
51 Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive - Model of recursive directories containing git repositories
55 my $repo = Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive->new( repo_dir => $Dir );
56 my $repository_list = $repo->repositories;
57 my $first_repository = $repository_list->[0];
58 my $named_repository = $repo->get_repository('Gitalist');
62 This class provides a list of Repositories recursively found in the given directory.
66 =head2 repo_dir (C<Path::Class::Dir>)
68 The filesystem root of the C<Repo>.
72 L<Gitalist::Git::CollectionOfRepositories>, L<Gitalist::Git::Repository>
76 See L<Gitalist> for authors.
80 See L<Gitalist> for the license.