3 class Gitalist::Git::CollectionOfRepositories::FromDirectory
4 with Gitalist::Git::CollectionOfRepositories {
5 use MooseX::Types::Common::String qw/NonEmptySimpleStr/;
6 use MooseX::Types::Path::Class qw/Dir/;
15 method debug_string { 'repository directory ' . $self->repo_dir }
18 # Make sure repo_dir is an absolute path so that
19 # ->contains() works correctly.
20 $self->repo_dir->resolve;
23 method _get_path_for_repository_name (NonEmptySimpleStr $name) {
24 my $path = $self->repo_dir->subdir($name)->resolve;
25 die "Directory traversal prohibited"
26 unless $self->repo_dir->contains($path);
30 method _get_repo_from_name (NonEmptySimpleStr $name) {
31 return Gitalist::Git::Repository->new($self->_get_path_for_repository_name($name));
35 method _build_repositories {
36 my $dh = $self->repo_dir->open || die "Could not open repo_dir";
38 while (my $dir_entry = $dh->read) {
39 # try to get a repository for each entry in repo_dir
41 my $p = $self->get_repository($dir_entry);
53 Gitalist::Git::CollectionOfRepositories::FromDirectory - Model of a directory containing git repositories
57 my $repo = Gitalist::Git::CollectionOfRepositories::FromDirectory->new( repo_dir => $Dir );
58 my $repository_list = $repo->repositories;
59 my $first_repository = $repository_list->[0];
60 my $named_repository = $repo->get_repository('Gitalist');
64 This class provides a list of Repositories found in the given directory.
68 =head2 repo_dir (C<Path::Class::Dir>)
70 The filesystem root of the C<Repo>.
74 L<Gitalist::Git::CollectionOfRepositories>, L<Gitalist::Git::Repository>
78 See L<Gitalist> for authors.
82 See L<Gitalist> for the license.