3 class Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive
4 with Gitalist::Git::CollectionOfRepositories {
5 use MooseX::Types::Common::String qw/NonEmptySimpleStr/;
6 use MooseX::Types::Path::Class qw/Dir/;
16 # Make sure repo_dir is an absolute path so that
17 # ->contains() works correctly.
18 $self->repo_dir->resolve;
21 method _get_path_for_repository_name (NonEmptySimpleStr $name) {
22 my $path = Path::Class::Dir->new( $name )->resolve;
23 die "Directory traversal prohibited: $path"
24 unless $self->repo_dir->contains($path);
29 method _build_repositories {
31 $self->repo_dir->recurse(
35 for my $repo ( @ret ) {
36 # no need to go further if parent is git dir
37 # never have a git repo in a git repo?
38 return if ( $repo->path->contains( $dir ) );
41 # pass directory as string
42 my $p = $self->get_repository("$dir");
57 Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive - Model of recursive directories containing git repositories
61 my $repo = Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive->new( repo_dir => $Dir );
62 my $repository_list = $repo->repositories;
63 my $first_repository = $repository_list->[0];
64 my $named_repository = $repo->get_repository('Gitalist');
68 This class provides a list of Repositories recursively found in the given directory.
72 =head2 repo_dir (C<Path::Class::Dir>)
74 The filesystem root of the C<Repo>.
78 L<Gitalist::Git::CollectionOfRepositories>, L<Gitalist::Git::Repository>
82 See L<Gitalist> for authors.
86 See L<Gitalist> for the license.