3 class Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive {
4 use MooseX::Types::Common::String qw/NonEmptySimpleStr/;
5 use MooseX::Types::Path::Class qw/Dir/;
8 use List::Util 'first';
17 method debug_string { 'repository directory ' . $self->repo_dir }
20 # Make sure repo_dir is an absolute path so that ->contains() works correctly.
21 $self->repo_dir->resolve;
24 method _find_repos(Dir $dir) {
26 $self->_is_git_repo($_) ? $_ : $self->_find_repos($_)
27 } grep $_->is_dir, $dir->children;
30 method _get_repo_from_name (NonEmptySimpleStr $name) {
31 my $repo = first { $_->name eq $name } $self->repositories->flatten
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;
42 method _build_repositories {
44 map { Gitalist::Git::Repository->new($_, $self->_get_repo_name("$_")) } $self->_find_repos( $self->repo_dir )
47 with 'Gitalist::Git::CollectionOfRepositories';
54 Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive - Model of recursive directories containing git repositories
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');
65 This class provides a list of Repositories recursively found in the given directory.
69 =head2 repo_dir (C<Path::Class::Dir>)
71 The filesystem root of the C<Repo>.
75 L<Gitalist::Git::CollectionOfRepositories>, L<Gitalist::Git::Repository>
79 See L<Gitalist> for authors.
83 See L<Gitalist> for the license.