NAME

    Mojolicious::Plugin::TemplatePerlish - Template::Perlish renderer
    plugin for Mojolicious

VERSION

    This document describes Mojolicious::Plugin::TemplatePerlish version
    0.002.

SYNOPSIS

       # Mojolicious
       $app->plugin('TemplatePerlish');
       $app->plugin(TemplatePerlish => {name => 'tpt'});
       $app->plugin(TemplatePerlish => {template_perlish => {start => '<%', stop => '%>'}});
    
       # Mojolicious::Lite
       plugin 'TemplatePerlish';
       plugin TemplatePerlish => {name => 'tpt'};
       plugin TemplatePerlish => {template_perlish => {start => '<%', stop => '%>'}});
    
       # Set as default handler, default name is 'tp'
       $app->renderer->default_handler('tp');
    
       # Render without setting as default handler
       $c->render(template => 'foo', handler => 'tp');

DESCRIPTION

    Mojolicious::Plugin::TemplatePerlish is a renderer for
    Template::Perlish templates. See Template::Perlish for details on the
    template format and available opitons, and
    Mojolicious::Guides::Rendering for general information on rendering in
    Mojolicious.

    Mojolicious helpers and stash values will be exposed directly as
    variables in the templates, and the current controller object will be
    available as c or self, similar to Mojolicious::Plugin::EPRenderer. See
    Mojolicious::Plugin::DefaultHelpers and Mojolicious::Plugin::TagHelpers
    for a list of all built-in helpers.

       $c->stash(description => 'template engine');
       $c->stash(engines => [qw(Template::Perlish Template::Toolkit)]);
    
       [% for my $engine (A 'engines') { %]
          [% engine %] is a [% description %].
       [% } %]
    
       [%= V('link_to')->('Perl', 'http://www.perl.org') %]

    Along with standard template files, inline and data section templates
    can be rendered in the standard way. Template files and data sections
    will be retrieved using Mojolicious::Renderer, so you should set
    "paths" in Mojolicious::Renderer to the appropriate paths towards the
    templates.

OPTIONS

    The following options are supported.

 cache

       # Mojolicious::Lite
       plugin TemplatePerlish => {cache => 0};

    By default this plugin caches templates to avoid recompiling the over
    and over. If you plan to have a long running job, or a lot of
    templates, you can disable caching passing a false value (like in the
    example above). A true value enables caching. If you pass a hash
    reference, it will be used as cache (so you can e.g. pre-populate it
    with subroutines, see "compile_as_sub" in Template::Perlish).

 name

       # Mojolicious::Lite
       plugin TemplatePerlish => {name => 'foo'};

    Handler name, defaults to tp.

 read_binmode

       # Mojolicious::Lite
       plugin TemplatePerlish => {read_binmode => ':raw'};

    When a template is loaded from a file, this is the binmode that is
    applied upon opening the file. Defaults to the string :encoding(UTF-8).

 template_perlish

       # Mojolicious::Lite
       plugin TemplatePerlish => {
          template_perlish => {
             start => '<%', # default is '[%'
             stop  => '%>', # default is '%]'
             variables => {foo => bar}, # default is {}
          }
       };

    Options for Template::Perlish constructor.

METHODS

 register

       $plugin->register(Mojolicious->new());
       $plugin->register(Mojolicious->new(), {name => 'foo'});

    Register renderer in Mojolicious application.

BUGS AND LIMITATIONS

    Report bugs either through RT or GitHub (patches welcome).

SEE ALSO

    Mojolicious. Most of the documentation and tests is copied from
    Mojolicious::Plugin::TemplateToolkit.

AUTHOR

    Flavio Poletti <polettix@cpan.org>

COPYRIGHT AND LICENSE

    Copyright (C) 2016 by Flavio Poletti <polettix@cpan.org>

    This module is free software. You can redistribute it and/or modify it
    under the terms of the Artistic License 2.0.

    This program is distributed in the hope that it will be useful, but
    without any warranty; without even the implied warranty of
    merchantability or fitness for a particular purpose.