| Gitalist documentation | Contained in the Gitalist distribution. |
Gitalist::Git::CollectionOfRepositories::FromListOfDirectories - Model of a collection of git repositories
my $collection = Gitalist::Git::CollectionOfRepositories::FromListOfDirectories->new( repos => [qw/
/path/to/repos1
/path/to/repos2
/] );
my $repository_list = $collection->repositories;
my $first_repository = $repository_list->[0];
my $named_repository = $repo->get_repository('Gitalist');
This class provides an abstraction for a list of Repository directories.
ArrayRef[NonEmptySimpleStr])A list of git repository directories
See Gitalist for authors.
See Gitalist for the license.
| Gitalist documentation | Contained in the Gitalist distribution. |
use MooseX::Declare; class Gitalist::Git::CollectionOfRepositories::FromListOfDirectories with Gitalist::Git::CollectionOfRepositories { use MooseX::Types::Common::String qw/NonEmptySimpleStr/; use MooseX::Types::Moose qw/ ArrayRef HashRef /; use MooseX::Types::Path::Class qw/Dir/; use File::Basename qw/basename/; use Path::Class qw/dir/; use Moose::Autobox; has repos => ( isa => ArrayRef[NonEmptySimpleStr], is => 'ro', required => 1, ); has _repos_by_name => ( isa => HashRef[Dir], is => 'ro', lazy_build => 1, traits => ['Hash'], handles => { _get_path_for_repository_name => 'get', }, ); method _build__repos_by_name { +{ map { basename($_) => dir($_) } $self->repos->flatten }; } ## Builders method _build_repositories { [ map { $self->get_repository(basename($_)) } $self->repos->flatten ]; } } # end class 1;