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) {
23 $self->repo_dir->recurse(
26 return unless ( $thing->is_dir );
27 $path = $thing if ( $thing->dir_list(-1) eq $name
28 && $self->_is_git_repo( $thing ) );
31 $path->resolve if $path;
32 die "Directory traversal prohibited: ".( $path || 'path undefined' )
33 unless $path and $self->repo_dir->contains($path);
38 method _build_repositories {
40 $self->repo_dir->recurse(
44 for my $repo ( @ret ) {
45 # no need to go further if parent is git dir
46 # never have a git repo in a git repo?
47 my $check_dir = $repo->path;
48 # go up one and ignore all in that path
49 # if in hidden .git directory
50 $check_dir = $check_dir->parent
51 if ( -f $check_dir->parent->file('.git', 'HEAD') );
52 return if ( $check_dir->contains( $dir ) );
55 # pass directory name as string
56 my @list = $dir->dir_list();
57 my $p = $self->get_repository($list[$#list]);
72 Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive - Model of recursive directories containing git repositories
76 my $repo = Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive->new( repo_dir => $Dir );
77 my $repository_list = $repo->repositories;
78 my $first_repository = $repository_list->[0];
79 my $named_repository = $repo->get_repository('Gitalist');
83 This class provides a list of Repositories recursively found in the given directory.
87 =head2 repo_dir (C<Path::Class::Dir>)
89 The filesystem root of the C<Repo>.
93 L<Gitalist::Git::CollectionOfRepositories>, L<Gitalist::Git::Repository>
97 See L<Gitalist> for authors.
101 See L<Gitalist> for the license.