qw/tree dispatch_types registered_dispatch_types
method_action_class action_container_class
preload_dispatch_types postload_dispatch_types
+ action_hash
/
);
# set the default pre- and and postloads
$obj->preload_dispatch_types( \@PRELOAD );
$obj->postload_dispatch_types( \@POSTLOAD );
+ $obj->action_hash({});
return $obj;
}
$namespace ||= '';
$namespace = '' if $namespace eq '/';
- my @match = $self->get_containers($namespace);
-
- return unless @match;
-
- if ( my $action = $match[-1]->get_action($name) ) {
- return $action if $action->namespace eq $namespace;
- }
+ return $self->action_hash->{ "$namespace/$name" };
}
=head2 $self->get_actions( $c, $action, $namespace )
return unless $reg + $priv;
my $namespace = $action->namespace;
+ my $name = $action->name;
+
my $node = $self->find_or_create_namespace_node( $namespace );
# Set the method value
- $node->getNodeValue->actions->{ $action->name } = $action;
+ $node->getNodeValue->actions->{ $name } = $action;
+
+ my $path = "$namespace/$name";
+
+ if ( exists $self->action_hash->{$path} and $self->action_hash->{$path} != $action ) {
+ warn "inconsistency: $path is already registered";
+ }
+
+ $self->action_hash->{$path} = $action;
}
sub find_or_create_namespace_node {
- my ( $self, $namespace, $parent, $visitor ) = @_;
+ my ( $self, $namespace ) = @_;
+
+ my $tree ||= $self->tree;
- $parent ||= $self->tree;
- $visitor ||= Tree::Simple::Visitor::FindByPath->new;
+ return $tree unless $namespace;
- if ($namespace) {
- for my $part ( split '/', $namespace ) {
- $visitor->setSearchPath($part);
- $parent->accept($visitor);
- my $child = $visitor->getResult;
+ my @namespace = split '/', $namespace;
+ return $self->_find_or_create_namespace_node( $tree, @namespace );
+}
- unless ($child) {
+sub _find_or_create_namespace_node {
+ my ( $self, $parent, $part, @namespace ) = @_;
- # Create a new tree node and an ActionContainer to form
- # its value.
+ return $parent unless $part;
- my $container =
- Catalyst::ActionContainer->new(
- { part => $part, actions => {} } );
- $child = $parent->addChild( Tree::Simple->new($container) );
- $visitor->setSearchPath($part);
- $parent->accept($visitor);
- $child = $visitor->getResult;
- }
+ my $child = ( grep { $_->getNodeValue->part eq $part } $parent->getAllChildren )[0];
- $parent = $child;
- }
- }
+ unless ($child) {
+ # Create a new tree node and an ActionContainer to form
+ # its value.
+
+ my $container =
+ Catalyst::ActionContainer->new(
+ { part => $part, actions => {} } );
+
+ $parent->addChild( $child = Tree::Simple->new($container) );
+ }
- return $parent;
+ $self->_find_or_create_namespace_node( $child, @namespace );
}
=head2 $self->setup_actions( $class, $context )