X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FGitalist.git;a=blobdiff_plain;f=lib%2FGitalist%2FModel%2FCollectionOfRepos.pm;h=1e709c4f9f4bf28510f78afee9e05622ba08eb02;hp=128d0baa1d95225315957710e98eba27eeed927d;hb=e33993c9be8b249ecb9f1570bb9057d4c28b3db8;hpb=8f7296d0b564f052d4b17dddbd553dc355b04f88 diff --git a/lib/Gitalist/Model/CollectionOfRepos.pm b/lib/Gitalist/Model/CollectionOfRepos.pm index 128d0ba..1e709c4 100644 --- a/lib/Gitalist/Model/CollectionOfRepos.pm +++ b/lib/Gitalist/Model/CollectionOfRepos.pm @@ -50,6 +50,16 @@ has repos => ( coerce => 1, ); +has class => ( + isa => NonEmptySimpleStr, + is => 'ro', +); + +has args => ( + isa => 'HashRef', + is => 'ro', + default => sub { {} }, +); has search_recursively => ( is => 'ro', @@ -83,26 +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; + return 'FromDirectory::WhiteList'; } elsif ($self->_repos_count && !$self->search_recursively) { - $class = 'Gitalist::Git::CollectionOfRepositories::FromListOfDirectories'; - $args{repos} = $self->repos; + return 'FromListOfDirectories'; } elsif($self->search_recursively) { - $class = 'Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive'; - $args{repo_dir} = $self->repo_dir; - } else { - $class = 'Gitalist::Git::CollectionOfRepositories::FromDirectory'; - $args{repo_dir} = $self->repo_dir; + 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); }