package Catalyst::AttrContainer;
use strict;
-use base qw/Class::Data::Inheritable Class::Accessor::Fast/;
+use base qw/Class::Accessor::Fast Class::Data::Inheritable/;
use Catalyst::Exception;
use NEXT;
# note - see attributes(3pm)
sub MODIFY_CODE_ATTRIBUTES {
my ( $class, $code, @attrs ) = @_;
- return if ( ( $attrs[0] eq 'lvalue' ) && ( @attrs == 1 ) );
$class->_attr_cache( { %{ $class->_attr_cache }, $code => [@attrs] } );
$class->_action_cache(
[ @{ $class->_action_cache }, [ $code, [@attrs] ] ] );
=head1 NAME
-Catalyst::AttrContainer
+Catalyst::AttrContainer - Handles code attribute storage and caching
=head1 SYNOPSIS
=head1 DESCRIPTION
+This class sets up the code attribute cache. It's a base class for
+L<Catalyst::Controller>.
+
=head1 METHODS
-=over 4
+=head2 FETCH_CODE_ATTRIBUTES
-=item FETCH_CODE_ATTRIBUTES
+Attribute function. See attributes(3pm)
-=item MODIFY_CODE_ATTRIBUTES
+=head2 MODIFY_CODE_ATTRIBUTES
-=back
+Attribute function. See attributes(3pm)
=head1 SEE ALSO
+L<Catalyst::Dispatcher>
L<Catalyst>.
-=head1 AUTHOR
+=head1 AUTHORS
-Sebastian Riedel, C<sri@cpan.org>
-Marcus Ramberg, C<mramberg@cpan.org>
+Catalyst Contributors, see Catalyst.pm
=head1 COPYRIGHT