X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FBase.pm;h=cd14a4cffe1454c13fbf639fdbc4f6e5b492ebb4;hb=1b1636b58ce5f1feabd0d125c3928c57e5a5cf3c;hp=c4a6dc7dca2e004f995543d1e7e3365c4a0cd5bf;hpb=1e514a515b9b9a740962392fb280cdb11737ff02;p=catagits%2FCatalyst-Runtime.git diff --git a/lib/Catalyst/Base.pm b/lib/Catalyst/Base.pm index c4a6dc7..cd14a4c 100644 --- a/lib/Catalyst/Base.pm +++ b/lib/Catalyst/Base.pm @@ -79,13 +79,16 @@ dispatch of actions for controllers. =head2 $self->action_namespace($c) -Determine the namespace for actions in this component. +Returns the private namespace for actions in this component. Defaults to a value +from the controller name (for e.g. MyApp::Controller::Foo::Bar becomes +"foo/bar") or can be overriden from the "namespace" config key. =cut sub action_namespace { my ( $self, $c ) = @_; - return $self->config->{namespace} if exists $self->config->{namespace}; + my $hash = (ref $self ? $self : $self->config); # hate app-is-class + return $hash->{namespace} if exists $hash->{namespace}; return Catalyst::Utils::class2prefix( ref($self) || $self, $c->config->{case_sensitive} ) || ''; @@ -93,11 +96,18 @@ sub action_namespace { =head2 $self->path_prefix($c) -alias for action_namespace +Returns the default path prefix for :Local, :LocalRegex and relative :Path +actions in this component. Defaults to the action_namespace or can be +overriden from the "path" config key. =cut -sub path_prefix { shift->action_namespace(@_); } +sub path_prefix { + my ( $self, $c ) = @_; + my $hash = (ref $self ? $self : $self->config); # hate app-is-class + return $hash->{path} if exists $hash->{path}; + return shift->action_namespace(@_); +} =head2 $self->register_actions($c) @@ -166,7 +176,9 @@ sub create_action { sub _parse_attrs { my ( $self, $c, $name, @attrs ) = @_; - my %attributes; + + my %raw_attributes; + foreach my $attr (@attrs) { # Parse out :Foo(bar) into Foo => bar etc (and arrayify) @@ -177,14 +189,36 @@ sub _parse_attrs { if ( defined $value ) { ( $value =~ s/^'(.*)'$/$1/ ) || ( $value =~ s/^"(.*)"/$1/ ); } + push( @{ $raw_attributes{$key} }, $value ); + } + } + + my $hash = (ref $self ? $self : $self->config); # hate app-is-class + + if (exists $hash->{actions} || exists $hash->{action}) { + my $a = $hash->{actions} || $hash->{action}; + %raw_attributes = ((exists $a->{'*'} ? %{$a->{'*'}} : ()), + %raw_attributes, + (exists $a->{$name} ? %{$a->{$name}} : ())); + } + + my %final_attributes; + + foreach my $key (keys %raw_attributes) { + + my $raw = $raw_attributes{$key}; + + foreach my $value (ref($raw) ? @$raw : $raw) { + my $meth = "_parse_${key}_attr"; if ( $self->can($meth) ) { ( $key, $value ) = $self->$meth( $c, $name, $value ); } - push( @{ $attributes{$key} }, $value ); + push( @{ $final_attributes{$key} }, $value ); } } - return \%attributes; + + return \%final_attributes; } sub _parse_Global_attr {