__PACKAGE__->mk_accessors(
qw/tree dispatch_types registered_dispatch_types
- method_action_class action_container_class/
+ method_action_class action_container_class reserved_actions/
);
# Preload these action types
# Postload these action types
our @POSTLOAD = qw/Index Default/;
+# Reserved action names
+our @RESERVED = qw/begin auto default index end/;
+
=head1 NAME
Catalyst::Dispatcher - The Catalyst Dispatcher
return 0;
}
- my $arguments = ( ref( $_[-1] ) eq 'ARRAY' ) ? pop(@_) : $c->req->args;
+ my $local_args = 0;
+ my $arguments = $c->req->args;
+ if ( ref( $_[-1] ) eq 'ARRAY' ) {
+ $arguments = pop(@_);
+ $local_args = 1;
+ }
my $result;
my $tail = $2;
$result = $c->get_action( $tail, $1 );
if ($result) {
- $command = $tail;
- push( @{$arguments}, @extra_args );
+ $local_args = 1;
+ $command = $tail;
+ unshift( @{$arguments}, @extra_args );
last DESCEND;
}
unshift( @extra_args, $tail );
}
- local $c->request->{arguments} = [ @{$arguments} ];
-
- $result->execute($c);
+ if ($local_args) {
+ local $c->request->{arguments} = [ @{$arguments} ];
+ $result->execute($c);
+ }
+ else { $result->execute($c) }
return $c->state;
}
}
# If not, move the last part path to args
-
unshift @args, pop @path;
}
+ $c->log->debug( 'Path is "' . $c->req->match . '"' )
+ if ( $c->debug && $c->req->match );
+
$c->log->debug( 'Arguments are "' . join( '/', @args ) . '"' )
if ( $c->debug && @args );
}
}
}
+ # Check if action name is reserved
+ my $reserved = 0;
+ for my $name ( @{ $self->reserved_actions } ) {
+ $reserved++ if $action->name eq $name;
+ }
+
# Pass the action to our dispatch types so they can register it if reqd.
- my $reg = 0;
- foreach my $type ( @{ $self->dispatch_types } ) {
- $reg++ if $type->register( $c, $action );
+ my $reg = $reserved;
+ unless ($reserved) {
+ foreach my $type ( @{ $self->dispatch_types } ) {
+ $reg++ if $type->register( $c, $action );
+ }
}
return unless $reg + $priv;
$self->dispatch_types( [] );
$self->registered_dispatch_types( {} );
+ $self->reserved_actions( \@RESERVED );
$self->method_action_class('Catalyst::Action');
$self->action_container_class('Catalyst::ActionContainer');
return unless $c->debug;
my $privates = Text::SimpleTable->new(
- [ 24, 'Private' ],
- [ 23, 'Class' ],
- [ 23, 'Method' ]
+ [ 20, 'Private' ],
+ [ 38, 'Class' ],
+ [ 12, 'Method' ]
);
my $has_private = 0;