X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Runtime.git;a=blobdiff_plain;f=lib%2FCatalyst%2FDispatchType%2FIndex.pm;h=63b864df226c3207bd8ad0d10de550d5975f1d39;hp=dd8b0105fce90fc5caa14d917217eae1aced69f0;hb=e5ecd5bc38bac3e2fcfaf643ea2a4c6ab46d7e57;hpb=b5ecfcf07b8ffe7e9984f0279c8781ce51c6ac6a diff --git a/lib/Catalyst/DispatchType/Index.pm b/lib/Catalyst/DispatchType/Index.pm index dd8b010..63b864d 100644 --- a/lib/Catalyst/DispatchType/Index.pm +++ b/lib/Catalyst/DispatchType/Index.pm @@ -1,7 +1,10 @@ package Catalyst::DispatchType::Index; -use strict; -use base qw/Catalyst::DispatchType/; +use Moose; +extends 'Catalyst::DispatchType'; + +#use strict; +#use base qw/Catalyst::DispatchType/; =head1 NAME @@ -17,6 +20,10 @@ See L. =head2 $self->match( $c, $path ) +Check if there's an index action for a given path, and set it up to use it +if there is; only matches a full URI - if $c->req->args is already set +this DispatchType is guaranteed not to match. + =cut sub match { @@ -24,7 +31,7 @@ sub match { return if @{ $c->req->args }; my $result = $c->get_action( 'index', $path ); - if ($result) { + if ($result && $result->match($c)) { $c->action($result); $c->namespace( $result->namespace ); $c->req->action('index'); @@ -34,6 +41,23 @@ sub match { return 0; } +=head2 $self->uri_for_action( $action, $captures ) + +get a URI part for an action; always returns undef is $captures is set +since index actions don't have captures + +=cut + +sub uri_for_action { + my ( $self, $action, $captures ) = @_; + + return undef if @$captures; + + return undef unless $action->name eq 'index'; + + return "/".$action->namespace; +} + =head1 AUTHOR Sebastian Riedel, C @@ -45,4 +69,6 @@ the same terms as Perl itself. =cut +__PACKAGE__->meta->make_immutable; + 1;