X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FBase.pm;h=1e1d5851bf932f21d4bec7d9f3c307d420820f09;hb=424b2705f759cef65acfaf8ea0f43e6bef75b534;hp=6448f3d570ee20909b74f7d5eb0d9c9f0d126f32;hpb=23f9d93414eadb11350029f13b51841d8309363b;p=catagits%2FCatalyst-Runtime.git diff --git a/lib/Catalyst/Base.pm b/lib/Catalyst/Base.pm index 6448f3d..1e1d585 100644 --- a/lib/Catalyst/Base.pm +++ b/lib/Catalyst/Base.pm @@ -4,7 +4,15 @@ use strict; use base qw/Class::Data::Inheritable Class::Accessor::Fast/; use NEXT; -__PACKAGE__->mk_classdata('_config'); +__PACKAGE__->mk_classdata($_) for qw/_cache _config/; +__PACKAGE__->_cache( [] ); + +# note - see attributes(3pm) +sub MODIFY_CODE_ATTRIBUTES { + my ( $class, $code, @attrs ) = @_; + push @{ $class->_cache }, [ $code, [@attrs] ]; + return (); +} =head1 NAME @@ -33,7 +41,6 @@ Catalyst::Base - Catalyst Universal Base Class # Methods can be a request step $c->forward(qw/MyApp::Model::Something forward_to_me/); - MyApp->action( 'index.html' => \&MyApp::Model::Something::forward_to_me ); # Or just methods print $c->comp('MyApp::Model::Something')->test; @@ -88,7 +95,9 @@ sub config { =cut -sub process { 1 } +sub process { die __PACKAGE__." did not override process."; } + +=back =head1 SEE ALSO @@ -97,6 +106,7 @@ L. =head1 AUTHOR Sebastian Riedel, C +Marcus Ramberg, C =head1 COPYRIGHT