3 class Gitalist::Git::CollectionOfRepositories::FromListOfDirectories with Gitalist::Git::CollectionOfRepositories {
4 use MooseX::Types::Common::String qw/NonEmptySimpleStr/;
5 use MooseX::Types::Moose qw/ ArrayRef HashRef /;
6 use MooseX::Types::Path::Class qw/Dir/;
7 use Gitalist::Git::Types qw/ ArrayRefOfDirs /;
8 use File::Basename qw/basename/;
9 use Path::Class qw/dir/;
13 isa => ArrayRefOfDirs,
18 has _repos_by_name => (
24 _get_path_for_repository_name => 'get',
28 method debug_string { 'repository directories ' . join(" ", map { $_."" } $self->repos->flatten) }
30 method _build__repos_by_name {
31 +{ map { basename($_) => dir($_) } $self->repos->flatten };
34 method _get_repo_from_name (NonEmptySimpleStr $name) {
35 return Gitalist::Git::Repository->new($self->_get_path_for_repository_name($name));
39 method _build_repositories {
40 [ map { $self->get_repository(basename($_)) } $self->repos->flatten ];
48 Gitalist::Git::CollectionOfRepositories::FromListOfDirectories - Model of a collection of git repositories
52 my $collection = Gitalist::Git::CollectionOfRepositories::FromListOfDirectories->new( repos => [qw/
56 my $repository_list = $collection->repositories;
57 my $first_repository = $repository_list->[0];
58 my $named_repository = $repo->get_repository('Gitalist');
62 This class provides an abstraction for a list of Repository directories.
66 =head2 repos (C<< ArrayRef[NonEmptySimpleStr] >>)
68 A list of git repository directories
72 L<Gitalist::Git::CollectionOfRepositories>, L<Gitalist::Git::Repository>
76 See L<Gitalist> for authors.
80 See L<Gitalist> for the license.