} elsif (ref($try) eq 'ARRAY') {
return $try;
}
- my @result = $self->_to_try($try)->($env, @match);
+ my @result = $self->_to_try($try, \@match)->($env, @match);
next unless @result and defined($result[0]);
if (ref($result[0]) eq 'ARRAY') {
return $result[0];
}
sub _to_try {
- my ($self, $try) = @_;
+ my ($self, $try, $more) = @_;
if (ref($try) eq 'CODE') {
if (defined(my $proto = prototype($try))) {
$self->_construct_node(
} else {
$try
}
+ } elsif (!ref($try) and ref($more->[0]) eq 'CODE') {
+ $self->_construct_node(
+ match => $self->_parser->parse($try), run => shift(@$more)
+ )->to_app;
} elsif (blessed($try) && $try->can('to_app')) {
$try->to_app;
} else {
sub _construct_node {
my ($self, %args) = @_;
- @args{keys %$_} = values %$_ for $self->node_args;
- $self->node_class->new(\%args);
+ $self->node_class->new({ %{$self->node_args}, %args });
}
1;
use strict;
use warnings FATAL => 'all';
-use Data::Dump qw(dump);
+use Data::Dumper::Concise;
use Test::More (
eval { require HTTP::Request::AsCGI }
? 'no_plan'
$self->show_landing(@_);
},
sub(/...) {
- sub (GET + /user) {
+ q(GET + /user) => sub {
$self->show_users(@_);
},
sub (/user/*) {
sub show_landing {
my ($self, @args) = @_;
+ local $self->{_dispatcher};
return [
200, ['Content-Type' => 'application/perl' ],
- [Data::Dump::dump @args],
+ [::Dumper \@args],
];
}
sub show_users {
my ($self, @args) = @_;
+ local $self->{_dispatcher};
return [
200, ['Content-Type' => 'application/perl' ],
- [Data::Dump::dump @args],
+ [::Dumper \@args],
];
}
sub show_user {
my ($self, @args) = @_;
+ local $self->{_dispatcher};
return [
200, ['Content-Type' => 'application/perl' ],
- [Data::Dump::dump @args],
+ [::Dumper \@args],
];
}
sub process_post {
my ($self, @args) = @_;
+ local $self->{_dispatcher};
return [
200, ['Content-Type' => 'application/perl' ],
- [Data::Dump::dump @args],
+ [::Dumper \@args],
];
}
}
'200 on GET';
{
- my ($self, $env, @noextra) = eval $get_landing->content;
+ my ($self, $env, @noextra) = @{eval $get_landing->content};
+ die $@ if $@;
is scalar(@noextra), 0, 'No extra stuff';
is ref($self), 't::Web::Simple::SubDispatchArgs', 'got object';
is ref($env), 'HASH', 'Got hashref';
'200 on GET';
{
- my ($self, $env, @noextra) = eval $get_users->content;
+ my ($self, $env, @noextra) = @{eval $get_users->content};
is scalar(@noextra), 0, 'No extra stuff';
is ref($self), 't::Web::Simple::SubDispatchArgs', 'got object';
is ref($env), 'HASH', 'Got hashref';
'200 on GET';
{
- my ($self, $env, @noextra) = eval $get_user->content;
+ my ($self, $env, @noextra) = @{eval $get_user->content};
is scalar(@noextra), 0, 'No extra stuff';
is ref($self), 't::Web::Simple::SubDispatchArgs', 'got object';
is ref($env), 'HASH', 'Got hashref';
'200 on POST';
{
- my ($self, $params, $env, @noextra) = eval $post_user->content;
+ my ($self, $params, $env, @noextra) = @{eval $post_user->content};
is scalar(@noextra), 0, 'No extra stuff';
is ref($self), 't::Web::Simple::SubDispatchArgs', 'got object';
is ref($params), 'HASH', 'Got POST hashref';