X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FBase.pm;h=addc3ae12e5f7de63f36ec965f592019be8f7482;hb=5b707014dd4a5a756d22bcafc6c99e2b00a52d06;hp=0c23e40aced407ad8da77d81d6368ac821e46873;hpb=aad72cc9d5a40a2b6b547340dcf629e4c233d87f;p=catagits%2FCatalyst-Runtime.git diff --git a/lib/Catalyst/Base.pm b/lib/Catalyst/Base.pm index 0c23e40..addc3ae 100644 --- a/lib/Catalyst/Base.pm +++ b/lib/Catalyst/Base.pm @@ -43,7 +43,12 @@ sub _AUTO : Private { sub _ACTION : Private { my ( $self, $c ) = @_; - $c->action->execute($c); + if ( ref $c->action + && $c->action->can('execute') + && $c->req->action ) + { + $c->action->execute($c); + } return !@{ $c->error }; } @@ -69,20 +74,19 @@ Catalyst Base Class =head1 METHODS -=over 4 - -=item $self->action_namespace($c) +=head2 $self->action_namespace($c) =cut sub action_namespace { my ( $self, $c ) = @_; - return Catalyst::Utils::class2prefix( ref $self, + return $self->config->{namespace} if exists $self->config->{namespace}; + return Catalyst::Utils::class2prefix( ref($self) || $self, $c->config->{case_sensitive} ) || ''; } -=item $self->register_actions($c) +=head2 $self->register_actions($c) =cut @@ -108,7 +112,7 @@ sub register_actions { my $code = $cache->[0]; my $method = $methods{$code}; next unless $method; - my $attrs = $self->_parse_attrs( @{ $cache->[1] } ); + my $attrs = $self->_parse_attrs( $c, $method, @{ $cache->[1] } ); if ( $attrs->{Private} && ( keys %$attrs > 1 ) ) { $c->log->debug( 'Bad action definition "' . join( ' ', @{ $cache->[1] } ) @@ -132,7 +136,7 @@ sub register_actions { } sub _parse_attrs { - my ( $self, @attrs ) = @_; + my ( $self, $c, $name, @attrs ) = @_; my %attributes; foreach my $attr (@attrs) { @@ -144,17 +148,45 @@ sub _parse_attrs { if ( defined $value ) { ( $value =~ s/^'(.*)'$/$1/ ) || ( $value =~ s/^"(.*)"/$1/ ); } + my $meth = "_parse_${key}_attr"; + if ( $self->can($meth) ) { + ( $key, $value ) = $self->$meth( $c, $name, $value ); + } push( @{ $attributes{$key} }, $value ); } } return \%attributes; } -=back +sub _parse_Global_attr { + my ( $self, $c, $name, $value ) = @_; + return $self->_parse_Path_attr( $c, $name, "/$name" ); +} + +*_parse_Absolute_attr = \&_parse_Global_attr; + +sub _parse_Local_attr { + my ( $self, $c, $name, $value ) = @_; + return $self->_parse_Path_attr( $c, $name, $name ); +} + +*_parse_Relative_attr = \&_parse_Local_attr; + +sub _parse_Path_attr { + my ( $self, $c, $name, $value ) = @_; + $value ||= ''; + if ( $value =~ m!^/! ) { + return ( 'Path', $value ); + } elsif ( length $value ) { + return ( 'Path', join( '/', $self->action_namespace($c), $value ) ); + } else { + return ( 'Path', $self->action_namespace($c) ); + } +} =head1 SEE ALSO -L. +L, L. =head1 AUTHOR