| Gitalist documentation | Contained in the Gitalist distribution. |
Gitalist::Git::CollectionOfRepositories - Interface and partial implementation of a collection of git repositories
package My::Example::CollectionOfRepositories;
use Moose::Role;
use namespace::autoclean;
with 'Gitalist::Git::CollectionOfRepositories';
sub _build_repositories {
my $self = shift;
[ $self->get_repository('Gitalist') ];
}
sub _get_path_for_repository_name {
my ($self, $name) = @_;
'/var/example/' . $name . '.git';
}
my $collection = My::Example::CollectionOfRepositories->new
my $repository_list = $collection->repositories;
my $only_repository = $repository_list->[0];
my $named_repository = $repo->get_repository('Gitalist');
This role provides an abstraction for a list of Repository directories.
An array of all Gitalist::Git::Repositorys.
Returns a Gitalist::Git::Repository for the given name.
If $name is not a valid git repository an exception will be thrown.
Gitalist::Git::CollectionOfRepositories::FromListOfDirectories, Gitalist::Git::CollectionOfRepositories::FromDirectory, Gitalist::Git::Repository.
See Gitalist for authors.
See Gitalist for the license.
| Gitalist documentation | Contained in the Gitalist distribution. |
use MooseX::Declare; role Gitalist::Git::CollectionOfRepositories { use MooseX::Types::Common::String qw/NonEmptySimpleStr/; use MooseX::Types::Moose qw/ArrayRef/; use Moose::Autobox; use aliased 'Gitalist::Git::Repository'; has repositories => ( is => 'ro', isa => ArrayRef['Gitalist::Git::Repository'], required => 1, lazy_build => 1, ); method get_repository (NonEmptySimpleStr $name) { my $path = $self->_get_path_for_repository_name($name); die "Not a valid git repository." unless $self->_is_git_repo($path); return Repository->new( $path ); } # Determine whether a given directory is a git repo. method _is_git_repo ($dir) { return -f $dir->file('HEAD') || -f $dir->file('.git', 'HEAD'); } requires qw/ _build_repositories _get_path_for_repository_name /; around _build_repositories { [sort { $a->name cmp $b->name } $self->$orig->flatten]; } } 1;