use base qw/Class::Data::Inheritable Class::Accessor::Fast/;
use NEXT;
-__PACKAGE__->mk_classdata('_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
# 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;
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
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
return $self->_config;
}
-=head3 process
+=item $c->process()
=cut
-sub process { 1 }
+sub process {
+ die( ( ref $_[0] || $_[0] ) . " did not override Catalyst::Base::process" );
+}
+
+=back
=head1 SEE ALSO
=head1 AUTHOR
Sebastian Riedel, C<sri@cpan.org>
+Marcus Ramberg, C<mramberg@cpan.org>
=head1 COPYRIGHT