X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FBase.pm;h=abe23e9cc03bfbf8ca7dd8166044f9ad6acdbfcf;hb=ac73326467a355b37917b030d8413c4838468aee;hp=7da4dbce0c16eb81215012388bc4fbc880520876;hpb=fc7ec1d96ee55d1bf42af3abce155ecb717b9e2b;p=catagits%2FCatalyst-Runtime.git diff --git a/lib/Catalyst/Base.pm b/lib/Catalyst/Base.pm index 7da4dbc..abe23e9 100644 --- a/lib/Catalyst/Base.pm +++ b/lib/Catalyst/Base.pm @@ -4,7 +4,14 @@ 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( [] ); + +sub MODIFY_CODE_ATTRIBUTES { + my ( $class, $code, @attrs ) = @_; + push @{ $class->_cache }, [ $code, [@attrs] ]; + return (); +} =head1 NAME @@ -48,7 +55,11 @@ This is the universal base class for Catalyst components It provides you with a generic new() for instantiation through Catalyst's component loader with config() support and a process() method placeholder. -=head2 METHODS +=head1 METHODS + +=over 4 + +=item new($c) =cut @@ -57,7 +68,14 @@ sub new { return $self->NEXT::new( $self->config ); } -=head3 config +# remember to leave blank lines between the consecutive =item's +# otherwise the pod tools don't recognize the subsequent =items + +=item $c->config + +=item $c->config($hashref) + +=item $c->config($key, $value, ...) =cut @@ -73,7 +91,7 @@ sub config { return $self->_config; } -=head3 process +=item $c->process() =cut