package Catalyst::AttrContainer; use strict; use base qw/Class::Accessor::Fast Class::Data::Inheritable/; use Catalyst::Exception; use NEXT; __PACKAGE__->mk_classdata($_) for qw/_attr_cache _action_cache/; __PACKAGE__->_attr_cache( {} ); __PACKAGE__->_action_cache( [] ); # note - see attributes(3pm) sub MODIFY_CODE_ATTRIBUTES { my ( $class, $code, @attrs ) = @_; $class->_attr_cache( { %{ $class->_attr_cache }, $code => [@attrs] } ); $class->_action_cache( [ @{ $class->_action_cache }, [ $code, [@attrs] ] ] ); return (); } sub FETCH_CODE_ATTRIBUTES { $_[0]->_attr_cache->{ $_[1] } || () } =head1 NAME Catalyst::AttrContainer =head1 SYNOPSIS =head1 DESCRIPTION This class sets up the code attribute cache. It's a base class for L. =head1 METHODS =head2 FETCH_CODE_ATTRIBUTES Attribute function. See attributes(3pm) =head2 MODIFY_CODE_ATTRIBUTES Attribute function. See attributes(3pm) =head1 SEE ALSO L L. =head1 AUTHOR Sebastian Riedel, C Marcus Ramberg, C =head1 COPYRIGHT This program is free software, you can redistribute it and/or modify it under the same terms as Perl itself. =cut 1;