);
+sub new {
+ my ( $class, $fields ) = @_;
+
+ $fields = { part => $fields, actions => {} } unless ref $fields;
+
+ $class->SUPER::new($fields);
+}
+
=head1 NAME
-Catalyst::Action - Catalyst Action
+Catalyst::ActionContainer - Catalyst Action Container
=head1 SYNOPSIS
=head1 DESCRIPTION
+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
-=over 4
+=head2 get_action($name)
+
+Returns an action from this container based on the action name, or undef
-=item part
+=cut
+
+sub get_action {
+ my ( $self, $name ) = @_;
+ return $self->actions->{$name} if defined $self->actions->{$name};
+ return;
+}
-=item actions
+=head2 add_action($action, [ $name ])
-=item new
+Adds an action, optionally providing a name to override $action->name
=cut
-sub new { # Dumbass constructor
- my ( $class, $attrs ) = @_;
- return bless { %{ $attrs || {} } }, $class;
+sub add_action {
+ my ( $self, $action, $name ) = @_;
+ $name ||= $action->name;
+ $self->actions->{$name} = $action;
}
-=back
+=head2 actions
+
+Accessor to the actions hashref, containing all actions in this container.
+
+=head2 part
+
+Accessor to the path part this container resolves to. Also what the container
+stringifies to.
=head1 AUTHOR