X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Runtime.git;a=blobdiff_plain;f=lib%2FCatalyst%2FBase.pm;h=ea2063acd4e5d6e919b31d5fbe8c5cf1ba321449;hp=2a6672b308e75ec51c650b43f3a3d90754271027;hb=b8f669f3c51dab87bfe9387dbaac0c07027abcfd;hpb=e7f1cf73b4e0e5863e901aaa0e6bda2e39bd0edc diff --git a/lib/Catalyst/Base.pm b/lib/Catalyst/Base.pm index 2a6672b..ea2063a 100644 --- a/lib/Catalyst/Base.pm +++ b/lib/Catalyst/Base.pm @@ -27,7 +27,7 @@ sub _BEGIN : Private { my ( $self, $c ) = @_; my $begin = ( $c->get_actions( 'begin', $c->namespace ) )[-1]; return 1 unless $begin; - $begin->execute($c); + $begin->dispatch( $c ); return !@{ $c->error }; } @@ -35,7 +35,7 @@ sub _AUTO : Private { my ( $self, $c ) = @_; my @auto = $c->get_actions( 'auto', $c->namespace ); foreach my $auto (@auto) { - $auto->execute($c); + $auto->dispatch( $c ); return 0 unless $c->state; } return 1; @@ -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->dispatch( $c ); + } return !@{ $c->error }; } @@ -51,7 +56,7 @@ sub _END : Private { my ( $self, $c ) = @_; my $end = ( $c->get_actions( 'end', $c->namespace ) )[-1]; return 1 unless $end; - $end->execute($c); + $end->dispatch( $c ); return !@{ $c->error }; } @@ -67,22 +72,36 @@ See L Catalyst Base Class +This is the base class for all Catalyst components. It also handles +dispatch of actions for controllers. + =head1 METHODS -=over 4 +=head2 $self->action_namespace($c) -=item $self->action_namespace($c) +Determine the namespace for actions in this component. =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->path_prefix($c) + +alias for action_namespace + +=cut + +sub path_prefix { shift->action_namespace(@_); } + +=head2 $self->register_actions($c) + +register all actions for this component based on a given context. =cut @@ -108,7 +127,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] } ) @@ -117,22 +136,26 @@ sub register_actions { next; } my $reverse = $namespace ? "$namespace/$method" : $method; - my $action = $self->_action_class->new( - { - name => $method, - code => $code, - reverse => $reverse, - namespace => $namespace, - class => $class, - attributes => $attrs, - } + my $action = $self->create_action( + name => $method, + code => $code, + reverse => $reverse, + namespace => $namespace, + class => $class, + attributes => $attrs, ); + $c->dispatcher->register( $c, $action ); } } +sub create_action { + my $self = shift; + $self->_action_class->new( { @_ } ); +} + sub _parse_attrs { - my ( $self, @attrs ) = @_; + my ( $self, $c, $name, @attrs ) = @_; my %attributes; foreach my $attr (@attrs) { @@ -144,13 +167,58 @@ 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" ); +} + +sub _parse_Absolute_attr { shift->_parse_Global_attr(@_); } + +sub _parse_Local_attr { + my ( $self, $c, $name, $value ) = @_; + return $self->_parse_Path_attr( $c, $name, $name ); +} + +sub _parse_Relative_attr { shift->_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->path_prefix($c), $value ) ); + } + else { + return ( 'Path', $self->path_prefix($c) ); + } +} + +sub _parse_Regex_attr { + my ( $self, $c, $name, $value ) = @_; + return ( 'Regex', $value ); +} + +sub _parse_Regexp_attr { shift->_parse_Regex_attr(@_); } + +sub _parse_LocalRegex_attr { + my ( $self, $c, $name, $value ) = @_; + unless ( $value =~ s/^\^// ) { $value = "(?:.*?)$value"; } + return ( 'Regex', '^' . $self->path_prefix($c) . "/${value}" ); +} + +sub _parse_LocalRegexp_attr { shift->_parse_LocalRegex_attr(@_); } =head1 SEE ALSO