X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FBase.pm;h=4c3fb7087d58f778ae542e2883fb87589ce4ffe1;hb=cd3bb2484489456f53fc03b568e34bfaf508a3cf;hp=472ef3992ea01ee4a486600c1f6b1238480417a7;hpb=f5771415ac7632c99baaa5810fd65cf30988ba5d;p=catagits%2FCatalyst-Runtime.git diff --git a/lib/Catalyst/Base.pm b/lib/Catalyst/Base.pm index 472ef39..4c3fb70 100644 --- a/lib/Catalyst/Base.pm +++ b/lib/Catalyst/Base.pm @@ -2,21 +2,22 @@ package Catalyst::Base; use strict; use base qw/Class::Data::Inheritable Class::Accessor::Fast/; +use Catalyst::Utils; use NEXT; -__PACKAGE__->mk_classdata($_) for qw/_attrcache _cache _config/; -__PACKAGE__->_cache( [] ); -__PACKAGE__->_attrcache( {} ); +__PACKAGE__->mk_classdata($_) for qw/_attr_cache _action_cache _config/; +__PACKAGE__->_attr_cache( {} ); +__PACKAGE__->_action_cache( [] ); # note - see attributes(3pm) sub MODIFY_CODE_ATTRIBUTES { my ( $class, $code, @attrs ) = @_; - $class->_attrcache->{$code} = [@attrs]; - push @{ $class->_cache }, [ $code, [@attrs] ]; + $class->_attr_cache->{$code} = [@attrs]; + push @{ $class->_action_cache }, [ $code, [@attrs] ]; return (); } -sub FETCH_CODE_ATTTRIBUTES { $_[0]->_attrcache->{ $_[1] } || () } +sub FETCH_CODE_ATTRIBUTES { $_[0]->_attr_cache->{ $_[1] } || () } =head1 NAME @@ -69,7 +70,12 @@ component loader with config() support and a process() method placeholder. sub new { my ( $self, $c ) = @_; - return $self->NEXT::new( $self->config ); + my $class = ref $self || $self; + my $appname = Catalyst::Utils::class2appclass($class); + my $suffix = Catalyst::Utils::class2classsuffix($class); + my $appconfig = $appname->config->{$suffix} || {}; + my $config = { %{ $self->config }, %{$appconfig} }; + return $self->NEXT::new($config); } # remember to leave blank lines between the consecutive =item's @@ -86,8 +92,8 @@ sub new { sub config { my $self = shift; $self->_config( {} ) unless $self->_config; - if ( $_[0] ) { - my $config = $_[1] ? {@_} : $_[0]; + if (@_) { + my $config = @_ > 1 ? {@_} : $_[0]; while ( my ( $key, $val ) = each %$config ) { $self->_config->{$key} = $val; } @@ -103,6 +109,10 @@ sub process { die( ( ref $_[0] || $_[0] ) . " did not override Catalyst::Base::process" ); } +=item FETCH_CODE_ATTRIBUTES + +=item MODIFY_CODE_ATTRIBUTES + =back =head1 SEE ALSO