X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FGitalist%2FModel%2FCollectionOfRepos.pm;h=1e709c4f9f4bf28510f78afee9e05622ba08eb02;hb=e33993c9be8b249ecb9f1570bb9057d4c28b3db8;hp=6c2d9a11f49d765f59c7a112387886f168d57ff1;hpb=b70462a4f5137a1444304a35616911094383b381;p=catagits%2FGitalist.git diff --git a/lib/Gitalist/Model/CollectionOfRepos.pm b/lib/Gitalist/Model/CollectionOfRepos.pm index 6c2d9a1..1e709c4 100644 --- a/lib/Gitalist/Model/CollectionOfRepos.pm +++ b/lib/Gitalist/Model/CollectionOfRepos.pm @@ -50,6 +50,23 @@ has repos => ( coerce => 1, ); +has class => ( + isa => NonEmptySimpleStr, + is => 'ro', +); + +has args => ( + isa => 'HashRef', + is => 'ro', + default => sub { {} }, +); + +has search_recursively => ( + is => 'ro', + isa => 'Bool', + default => 0, +); + has export_ok => ( is => 'ro', isa => 'Str', @@ -60,7 +77,6 @@ has whitelist => ( isa => 'Str', ); - sub _build_repo_dir { my $self = shift; $ENV{GITALIST_REPO_DIR} ? @@ -77,24 +93,41 @@ after BUILD => sub { $self->_repos_count || $self->repo_dir; }; -sub build_per_context_instance { - my ($self, $app) = @_; +sub _default_model_class { + my($self) = @_; - my %args = (export_ok => $self->export_ok || ''); - my $class; if($self->whitelist && -f $self->whitelist) { - $class = 'Gitalist::Git::CollectionOfRepositories::FromDirectory::WhiteList'; - $args{repo_dir} = $self->repo_dir; - $args{whitelist} = $self->whitelist; - } elsif ($self->_repos_count) { - $class = 'Gitalist::Git::CollectionOfRepositories::FromListOfDirectories'; - $args{repos} = $self->repos; - } - else { - $class = 'Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive'; - $args{repo_dir} = $self->repo_dir; + return 'FromDirectory::WhiteList'; + } elsif ($self->_repos_count && !$self->search_recursively) { + return 'FromListOfDirectories'; + } elsif($self->search_recursively) { + return 'FromDirectoryRecursive'; } + return 'FromDirectory'; +} + +sub build_per_context_instance { + my ($self, $app) = @_; + + my %args = ( + export_ok => $self->export_ok || '', + %{ $self->args } + ); + + my $class = $self->class; + Class::MOP::load_class($class) if $class; + + my $default = $self->_default_model_class; + + $args{whitelist} = $self->whitelist if $default eq 'FromDirectory::WhiteList'; + $args{repos} = $self->repos if $default eq 'FromListOfDirectories'; + $args{repo_dir} = $self->repo_dir if $default =~ /\b(?:WhiteList|FromDirectory(?:Recursive)?)$/; + + $class ||= "Gitalist::Git::CollectionOfRepositories::$default"; + + $app->log->debug("Using class '$class'"); + return $class->new(%args); } @@ -102,6 +135,12 @@ __PACKAGE__->meta->make_immutable; __END__ +=encoding UTF-8 + +=head1 NAME + +Gitalist::Model::CollectionOfRepos - Model::CollectionOfRepos module for Gitalist + =head1 AUTHORS See L for authors.