NAME Text::Forge - Templates with embedded Perl VERSION version 6.02 SYNOPSIS use Text::Forge; my $forge = Text::Forge->new; # template in external file print $forge->run('path/to/template'); # template passed as reference print $forge->run(\' <% my $d = scalar localtime %>The date is <%= $d %> '); # Outputs: The date is Fri Nov 26 11:32:22 2010 DESCRIPTION This module uses templates to generate documents dynamically. Templates are normal text files with a bit of special syntax that allows Perl code to be embedded. The following tags are supported: <% %> code block (no output) <%= %> interpolate, result is HTML escaped <%? %> interpolate, result is URI escaped <%$ %> interpolate, no escaping (let's be careful) <%# %> comment All blocks are evaluated within the same lexical scope (so my variables declared in one block are visible in subsequent blocks). Code blocks contain straight Perl code; it is executed, but nothing is output. Interpolation blocks are evaluated and the result inserted into the template. Templates are compiled into normal Perl methods. They can be passed arguments, as you might expect: print $forge->run( \'<% my %args = @_ %>Name is <%= $args{name} %>', name => 'foo' ); The $self variable is available within all templates, and is a reference to the Text::Forge instance that is generating the document. This allows subclasses to provide customization and context to templates. Anything printed to standard output (STDOUT) becomes part of the template. Any errors in compiling or executing a template raises an exception. Errors should correctly reference the template line causing the problem. If a block is followed solely by whitespace up to the next newline, that whitespace (including the newline) will be suppressed from the output. If you really want a newline, add another newline after the block. The idea is that the blocks themselves shouldn't affect the formatting. METHODS new Constructor. Returns a Text::Forge instance. my $forge = Text::Forge->new(%options); run Generate a template. The first argument is the template, which may be either a file path or a reference to a scalar. Any additional arguments are passed to the template. my $content = $forge->run('path/to/my/template', name => 'foo'); If a path is supplied and is not absolute, it will be searched for within the list of "search_paths". The generated output is returned. cache my $forge = Text::Forge->new; $forge->cache(1); Specifies whether templates should be cached. Defaults to true. If caching is enabled, templates are compiled into subroutines once and then reused. If you want to ensure templates always reflect the latest changes on disk (such as during development), set cache() to false. If you want to maximize performance, set cache() to true. charset my $forge = Text::Forge->new; $forge->charset('iso-8859-1'); Specifies the character encoding to use for templates. Defaults to Unicode (utf8). search_paths The list of directories to search for relative template paths. my $forge = Text::Forge->new; $forge->search_paths('/app/templates', '.'); # will look for /app/templates/header and ./header $forge->run('header'); content Returns the result of the last call to run(). TEMPLATE METHODS The following methods are intended for use *within* templates. It's all the same object though, so knock yourself out. include Include one template within another. For example, if you want to insert a "header" template within another template. Note that arguments can be passed to included templates and values can be returned (like normal function calls). my $forge = Text::Forge->new; $forge->run(\'<% $self->include("header", title => 'Hi') %>Hello'); capture Capture the output of a template. Used to capture (but not necessarily include) one template within another. For example: my $forge = Text::Forge->new; $forge->run(\' <% my $pagination = $self->capture(sub { %> Page