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=fbe9faad9e8b6fc932bf5899e81c3392a7ca6bf8;hp=dd8b0105fce90fc5caa14d917217eae1aced69f0;hb=ea0e58d9d85d93bf94c3ffa6b4d7b71b200bbdf1;hpb=b5ecfcf07b8ffe7e9984f0279c8781ce51c6ac6a diff --git a/lib/Catalyst/DispatchType/Index.pm b/lib/Catalyst/DispatchType/Index.pm index dd8b010..fbe9faa 100644 --- a/lib/Catalyst/DispatchType/Index.pm +++ b/lib/Catalyst/DispatchType/Index.pm @@ -17,6 +17,9 @@ 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. + =cut sub match { @@ -24,7 +27,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 +37,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