3 class Gitalist::Git::CollectionOfProjects::FromDirectory
4 with Gitalist::Git::CollectionOfProjects {
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_project_name (NonEmptySimpleStr $name) {
22 my $path = $self->repo_dir->subdir($name)->resolve;
23 die "Directory traversal prohibited"
24 unless $self->repo_dir->contains($path);
29 method _build_projects {
30 my $dh = $self->repo_dir->open || die "Could not open repo_dir";
32 while (my $dir_entry = $dh->read) {
33 # try to get a project for each entry in repo_dir
35 my $p = $self->get_project($dir_entry);
47 Gitalist::Git::CollectionOfProjects::FromDirectory - Model of a repository directory
51 my $repo = Gitalist::Git::CollectionOfProjects::FromDirectory->new( repo_dir => $Dir );
52 my $project_list = $repo->projects;
53 my $first_project = $project_list->[0];
54 my $named_project = $repo->get_project('Gitalist');
58 This class models a Gitalist Repo, which is a collection of
59 Projects (git repositories). It is used for creating Project
65 =head2 repo_dir (C<Path::Class::Dir>)
67 The filesystem root of the C<Repo>.
71 An array of all L<Gitalist::Git::Project>s found in C<repo_dir>.
77 =head2 get_project (Str $name)
79 Returns a L<Gitalist::Git::Project> for the given name.
80 If C<$name> is not a valid git repository under C<$repo_dir>, an exception
87 L<Gitalist::Git::Project>
92 See L<Gitalist> for authors.
96 See L<Gitalist> for the license.