use strict;
use base qw/Class::Accessor::Fast/;
-__PACKAGE__->mk_accessors(qw/part actions/);
-
-use overload (
-
- # Stringify to path part for tree search
- q{""} => sub { shift->{part} },
-
-);
-
=head1 NAME
Catalyst::ActionContainer - Catalyst Action Container
This is a container for actions. The dispatcher sets up a tree of these
to represent the various dispatch points in your application.
-=head1 METHODS
+=cut
-=head2 get_action($name)
+__PACKAGE__->mk_accessors(qw/part actions/);
+
+use overload (
+
+ # Stringify to path part for tree search
+ q{""} => sub { shift->{part} },
+
+);
+
+sub new {
+ my ( $class, $fields ) = @_;
+
+ $fields = { part => $fields, actions => {} } unless ref $fields;
+
+ $class->SUPER::new($fields);
+}
-Returns an action from this container based on the action name, or undef
-=cut
sub get_action {
my ( $self, $name ) = @_;
return;
}
+sub add_action {
+ my ( $self, $action, $name ) = @_;
+ $name ||= $action->name;
+ $self->actions->{$name} = $action;
+}
+
+1;
+
+__END__
+
+=head1 METHODS
+
+=head2 new(\%data | $part)
+
+Can be called with { part => $part, actions => \%actions } for full
+construction or with just a part, which will result in an empty actions
+hashref to be populated via add_action later
+
+=head2 get_action($name)
+
+Returns an action from this container based on the action name, or undef
+
+=head2 add_action($action, [ $name ])
+
+Adds an action, optionally providing a name to override $action->name
+
=head2 actions
Accessor to the actions hashref, containing all actions in this container.
=head1 AUTHOR
-Matt S. Trout
+Matt S. Trout
=head1 COPYRIGHT