X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FController.pm;h=cf6157a83d6d7a5bd46d3a65ac307ef3cbd553bb;hb=ed9d06b6c87f01030c2189199fe0351ef674e9e7;hp=47ec9f0c8db190b300590ded4f54b179979cc9e3;hpb=e87273a4374fb0d8da5479a826f9c847a50546cf;p=catagits%2FCatalyst-Runtime.git diff --git a/lib/Catalyst/Controller.pm b/lib/Catalyst/Controller.pm index 47ec9f0..cf6157a 100644 --- a/lib/Catalyst/Controller.pm +++ b/lib/Catalyst/Controller.pm @@ -182,11 +182,10 @@ around path_prefix => sub { sub get_action_methods { my $self = shift; my $meta = find_meta($self) || confess("No metaclass setup for $self"); - confess("Metaclass " - . ref($meta) . " for " - . $meta->name - . " cannot support register_actions." ) - unless $meta->can('get_nearest_methods_with_attributes'); + confess( + sprintf "Metaclass %s for %s cannot support register_actions.", + ref $meta, $meta->name, + ) unless $meta->can('get_nearest_methods_with_attributes'); my @methods = $meta->get_nearest_methods_with_attributes; # actions specified via config are also action_methods @@ -196,6 +195,12 @@ sub get_action_methods { $meta->find_method_by_name($_) || confess( sprintf 'Action "%s" is not available from controller %s', $_, ref $self ) + } grep { + # '*' is a special action configuration key to apply config to all + # actions. It's not to be looked up as a method + # name. _controller_actions should probably be cleaned up before + # we even get here. + $_ ne '*' } keys %{ $self->_controller_actions } ) if ( ref $self ); return uniq @methods; @@ -302,10 +307,21 @@ sub _parse_attrs { $actions = $self->merge_config_hashes($cfg->{actions}, $cfg->{action}); } - %raw_attributes = ((exists $actions->{'*'} ? %{$actions->{'*'}} : ()), - %raw_attributes, - (exists $actions->{$name} ? %{$actions->{$name}} : ())); + %raw_attributes = ( + %raw_attributes, + exists $actions->{$name} ? %{ $actions->{$name } } : (), + ); + # Private actions with additional attributes will raise a warning and then + # be ignored. Adding '*' arguments to the default _DISPATCH / etc. methods, + # which are Private, will prevent those from being registered. They should + # probably be turned into :Actions instead, or we might want to otherwise + # disambiguate between those built-in internal actions and user-level + # Private ones. + %raw_attributes = ( + (exists $actions->{'*'} ? %{ $actions->{'*'} } : ()), + %raw_attributes, + ) unless $raw_attributes{Private}; my %final_attributes;