X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FBase.pm;h=472ef3992ea01ee4a486600c1f6b1238480417a7;hb=f5771415ac7632c99baaa5810fd65cf30988ba5d;hp=1e1d5851bf932f21d4bec7d9f3c307d420820f09;hpb=61b1e958102e2371a79e07a7e2cdbb371797d202;p=catagits%2FCatalyst-Runtime.git diff --git a/lib/Catalyst/Base.pm b/lib/Catalyst/Base.pm index 1e1d585..472ef39 100644 --- a/lib/Catalyst/Base.pm +++ b/lib/Catalyst/Base.pm @@ -4,16 +4,20 @@ use strict; use base qw/Class::Data::Inheritable Class::Accessor::Fast/; use NEXT; -__PACKAGE__->mk_classdata($_) for qw/_cache _config/; +__PACKAGE__->mk_classdata($_) for qw/_attrcache _cache _config/; __PACKAGE__->_cache( [] ); +__PACKAGE__->_attrcache( {} ); # note - see attributes(3pm) sub MODIFY_CODE_ATTRIBUTES { my ( $class, $code, @attrs ) = @_; + $class->_attrcache->{$code} = [@attrs]; push @{ $class->_cache }, [ $code, [@attrs] ]; return (); } +sub FETCH_CODE_ATTTRIBUTES { $_[0]->_attrcache->{ $_[1] } || () } + =head1 NAME Catalyst::Base - Catalyst Universal Base Class @@ -95,7 +99,9 @@ sub config { =cut -sub process { die __PACKAGE__." did not override process."; } +sub process { + die( ( ref $_[0] || $_[0] ) . " did not override Catalyst::Base::process" ); +} =back