X-Git-Url: https://git.decadent.org.uk/gitweb/?a=blobdiff_plain;f=lib%2FMaypole%2FView%2FTT.pm;h=13130e53ec1154c6ecfe1c44019db12582265096;hb=5ca6a1765a44c39b23e7bab0e2ba636dbc6b57a8;hp=40fa5651dcc9480db76f856e5f1a0a40e8aeb44b;hpb=8617321ebf13ce6b63d41a65a003d153f2b5cc5e;p=maypole.git diff --git a/lib/Maypole/View/TT.pm b/lib/Maypole/View/TT.pm index 40fa565..13130e5 100644 --- a/lib/Maypole/View/TT.pm +++ b/lib/Maypole/View/TT.pm @@ -12,14 +12,8 @@ sub template { unless ($self->{tt}) { my $view_options = $r->config->view_options || {}; - (my $driver_name = ref $r) =~ s/::/_/g; - my $compile_dir = catdir(tmpdir(), $driver_name); - $self->{provider} = Template::Provider->new( - COMPILE_DIR => $compile_dir, - %$view_options, - ); + $self->{provider} = Template::Provider->new($view_options); $self->{tt} = Template->new({ - COMPILE_DIR => $compile_dir, %$view_options, LOAD_TEMPLATES => [ $self->{provider} ], }); @@ -27,8 +21,12 @@ sub template { $self->{provider}->include_path([ $self->paths($r) ]); + my $template_file = $r->template; + my $ext = $r->config->template_extension; + $template_file .= $ext if defined $ext; + my $output; - if ($self->{tt}->process( $r->template, { $self->vars($r) }, \$output )) { + if ($self->{tt}->process($template_file, { $self->vars($r) }, \$output )) { $r->{output} = $output; return OK; } @@ -56,14 +54,15 @@ Maypole::View::TT - A Template Toolkit view class for Maypole =head1 DESCRIPTION -This is the default view class for Maypole; it uses the Template Toolkit -to fill in templates with the objects produced by Maypole's model classes. -Please see the Maypole manual, and in particular, the C chapter, -for the template variables available and for a refresher on how template -components are resolved. +This is the default view class for Maypole; it uses the Template Toolkit to +fill in templates with the objects produced by Maypole's model classes. Please +see the L, and in particular, the +L chapter for the template variables available and +for a refresher on how template components are resolved. The underlying Template toolkit object is configured through -C<$r-Econfig-Eview_options>. See L