package Catalyst::View::Component::SubInclude::Visit;
-use warnings;
-use strict;
-
+use Moose;
use Carp qw/croak/;
-use namespace::clean qw/croak/;
+use MooseX::Types::Moose qw/ Bool /;
+use namespace::clean -except => 'meta';
=head1 NAME
=head1 VERSION
-Version 0.02
+Version 0.07
=cut
-our $VERSION = '0.02';
+our $VERSION = '0.07';
=head1 SYNOPSIS
This method is only supported when using L<Catalyst> version 5.71000 or newer.
+B<WARNING: As of Catalyst version 5.71000, this plugin doesn't work for chained
+actions with captured arguments>. Apparently, C<visit> doesn't handle this type
+of actions yet.
+
=head1 CLASS METHODS
=head2 C<generate_subinclude( $c, $path, @args )>
-This will translate to the following call:
+This is (roughly) equivalent to the following call:
$c->visit( $path, @args );
+But it will handle all the nasty details such as localizing the stash,
+parameters and response body. This is necessary to keep behavior consistent
+with the other plugins.
+
=cut
+has keep_stash => (
+ isa => Bool,
+ is => 'ro',
+ default => 0,
+);
+
sub generate_subinclude {
- my ($class, $c, $path, @params) = @_;
+ my ($self, $c, $path, @params) = @_;
croak "subincludes through visit() require Catalyst version 5.71000 or newer"
unless $c->can('visit');
- $c->visit( $path, @params );
- $c->res->{body};
+ {
+ local $c->{stash} = $self->keep_stash ? $c->{stash} : {};
+
+ local $c->request->{parameters} =
+ ref $params[-1] eq 'HASH' ? pop @params : {};
+
+ local $c->response->{body};
+
+ my $captures = ref $params[0] eq 'ARRAY' ? shift @params : [];
+ $c->visit( $path, $captures, \@params );
+
+ return $c->response->{body};
+ }
+
}
=head1 SEE ALSO
=cut
+__PACKAGE__->meta->make_immutable;
1;