1Template(3)           User Contributed Perl Documentation          Template(3)
2
3
4

NAME

6       Template - Front-end module to the Template Toolkit
7

SYNOPSIS

9           use Template;
10
11           # some useful options (see below for full list)
12           my $config = {
13               INCLUDE_PATH => '/search/path',  # or list ref
14               INTERPOLATE  => 1,               # expand "$var" in plain text
15               POST_CHOMP   => 1,               # cleanup whitespace
16               PRE_PROCESS  => 'header',        # prefix each template
17               EVAL_PERL    => 1,               # evaluate Perl code blocks
18           };
19
20           # create Template object
21           my $template = Template->new($config);
22
23           # define template variables for replacement
24           my $vars = {
25               var1  => $value,
26               var2  => \%hash,
27               var3  => \@list,
28               var4  => \&code,
29               var5  => $object,
30           };
31
32           # specify input filename, or file handle, text reference, etc.
33           my $input = 'myfile.html';
34
35           # process input template, substituting variables
36           $template->process($input, $vars)
37               || die $template->error();
38

DESCRIPTION

40       This documentation describes the Template module which is the direct
41       Perl interface into the Template Toolkit.  It covers the use of the
42       module and gives a brief summary of configuration options and template
43       directives.  Please see Template::Manual for the complete reference
44       manual which goes into much greater depth about the features and use of
45       the Template Toolkit.  The Template::Tutorial is also available as an
46       introductory guide to using the Template Toolkit.
47

METHODS

49   new(\%config)
50       The "new()" constructor method (implemented by the Template::Base base
51       class) instantiates a new "Template" object. A reference to a hash
52       array of configuration items may be passed as a parameter.
53
54           my $tt = Template->new({
55               INCLUDE_PATH => '/usr/local/templates',
56               EVAL_PERL    => 1,
57           }) || die $Template::ERROR, "\n";
58
59       A reference to a new "Template" object is returned, or undef on error.
60       In the latter case, the error message can be retrieved by calling
61       error() as a class method or by examining the $Template::ERROR package
62       variable directly.
63
64           my $tt = Template->new(\%config)
65               || die Template->error(), "\n";
66
67           my $tt = Template->new(\%config)
68               || die $Template::ERROR, "\n";
69
70       For convenience, configuration items may also be specified as a list of
71       items instead of a hash array reference.  These are automatically
72       folded into a hash array by the constructor.
73
74           my $tt = Template->new(INCLUDE_PATH => '/tmp', POST_CHOMP => 1)
75               || die $Template::ERROR, "\n";
76
77   process($template, \%vars, $output, %options)
78       The "process()" method is called to process a template. The first
79       parameter indicates the input template as one of:
80
81       •   a filename relative to "INCLUDE_PATH", if defined
82
83       •   a reference to a text string containing the template text
84
85       •   a file handle reference (e.g. "IO::Handle" or sub-class) or "GLOB"
86           (e.g. "\*STDIN"), from which the template can be read.
87
88       A reference to a hash array may be passed as the second parameter,
89       containing definitions of template variables.
90
91           # filename
92           $tt->process('welcome.tt2')
93               || die $tt->error(), "\n";
94
95           # text reference
96           $text = "[% INCLUDE header %]\nHello world!\n[% INCLUDE footer %]";
97           $tt->process(\$text)
98               || die $tt->error(), "\n";
99
100           # file handle (GLOB)
101           $tt->process(\*DATA)
102               || die $tt->error(), "\n";
103
104           __END__
105           [% INCLUDE header %]
106           This is a template defined in the __END__ section which is
107           accessible via the DATA "file handle".
108           [% INCLUDE footer %]
109
110       By default, the processed template output is printed to "STDOUT". The
111       "process()" method then returns 1 to indicate success. A third
112       parameter may be passed to the "process()" method to specify a
113       different output location.  This value may be one of:
114
115       •   a plain string indicating a filename which will be opened (relative
116           to "OUTPUT_PATH", if defined) and the output written to
117
118       •   a file GLOB opened ready for output
119
120       •   a reference to a scalar (e.g. a text string) to which output/error
121           is appended
122
123       •   a reference to a subroutine which is called, passing the output as
124           a parameter
125
126       •   any object reference which implements a "print()" method (e.g.
127           "IO::Handle", "Apache::Request", etc.) which will be called,
128           passing the generated output as a parameter.
129
130       Examples:
131
132           # output filename
133           $tt->process('welcome.tt2', $vars, 'welcome.html')
134               || die $tt->error(), "\n";
135
136           # reference to output subroutine
137           sub myout {
138               my $output = shift;
139               ...
140           }
141           $tt->process('welcome.tt2', $vars, \&myout)
142               || die $tt->error(), "\n";
143
144           # reference to output text string
145           my $output = '';
146           $tt->process('welcome.tt2', $vars, \$output)
147               || die $tt->error(), "\n";
148
149           print "output: $output\n";
150
151       In an Apache/mod_perl handler:
152
153           sub handler {
154               my $req = shift;
155
156               # ...your code here...
157
158               # direct output to Apache::Request via $req->print($output)
159               $tt->process($file, $vars, $req) || do {
160                   $req->log_reason($tt->error());
161                   return SERVER_ERROR;
162               };
163               return OK;
164           }
165
166       After the optional third output argument can come an optional reference
167       to a hash or a list of "(name, value)" pairs providing further options
168       for the output.  The only option currently supported is "binmode"
169       which, when set to any true value will ensure that files created (but
170       not any existing file handles passed) will be set to binary mode.
171
172           # either: hash reference of options
173           $tt->process($infile, $vars, $outfile, { binmode => 1 })
174               || die $tt->error(), "\n";
175
176           # or: list of name, value pairs
177           $tt->process($infile, $vars, $outfile, binmode => 1)
178               || die $tt->error(), "\n";
179
180       Alternately, the "binmode" argument can specify a particular IO layer
181       such as ":utf8".
182
183           $tt->process($infile, $vars, $outfile, binmode => ':utf8')
184               || die $tt->error(), "\n";
185
186       The "OUTPUT" configuration item can be used to specify a default output
187       location other than "\*STDOUT".  The "OUTPUT_PATH" specifies a
188       directory which should be prefixed to all output locations specified as
189       filenames.
190
191           my $tt = Template->new({
192               OUTPUT      => sub { ... },       # default
193               OUTPUT_PATH => '/tmp',
194           ...
195           }) || die Template->error(), "\n";
196
197           # use default OUTPUT (sub is called)
198           $tt->process('welcome.tt2', $vars)
199               || die $tt->error(), "\n";
200
201           # write file to '/tmp/welcome.html'
202           $tt->process('welcome.tt2', $vars, 'welcome.html')
203               || die $tt->error(), "\n";
204
205       The "process()" method returns 1 on success or "undef" on error. The
206       error message generated in the latter case can be retrieved by calling
207       the error() method. See also "CONFIGURATION SUMMARY" which describes
208       how error handling may be further customised.
209
210   error()
211       When called as a class method, it returns the value of the $ERROR
212       package variable.  Thus, the following are equivalent.
213
214           my $tt = Template->new()
215               || die Template->error(), "\n";
216
217           my $tt = Template->new()
218               || die $Template::ERROR, "\n";
219
220       When called as an object method, it returns the value of the internal
221       "_ERROR" variable, as set by an error condition in a previous call to
222       process().
223
224           $tt->process('welcome.tt2')
225               || die $tt->error(), "\n";
226
227       Errors are represented in the Template Toolkit by objects of the
228       Template::Exception class. If the process() method returns a false
229       value then the "error()" method can be called to return an object of
230       this class.  The type() and info() methods can called on the object to
231       retrieve the error type and information string, respectively. The
232       as_string() method can be called to return a string of the form "$type
233       - $info". This method is also overloaded onto the stringification
234       operator allowing the object reference itself to be printed to return
235       the formatted error string.
236
237           $tt->process('somefile') || do {
238               my $error = $tt->error();
239               print "error type: ", $error->type(), "\n";
240               print "error info: ", $error->info(), "\n";
241               print $error, "\n";
242           };
243
244   service()
245       The "Template" module delegates most of the effort of processing
246       templates to an underlying Template::Service object.  This method
247       returns a reference to that object.
248
249   context()
250       The Template::Service module uses a core Template::Context object for
251       runtime processing of templates.  This method returns a reference to
252       that object and is equivalent to "$template->service->context()".
253
254   template($name)
255       This method is a simple wrapper around the Template::Context method of
256       the same name.  It returns a compiled template for the source provided
257       as an argument.
258

CONFIGURATION SUMMARY

260       The following list gives a short summary of each Template Toolkit
261       configuration option.  See Template::Manual::Config for full details.
262
263   Template Style and Parsing Options
264       ENCODING
265
266       Specifies the character encoding.
267
268       START_TAG, END_TAG
269
270       Define tokens that indicate start and end of directives (default:
271       '"[%"' and '"%]"').
272
273       TAG_STYLE
274
275       Set "START_TAG" and "END_TAG" according to a pre-defined style
276       (default: '"template"', as above).
277
278       PRE_CHOMP, POST_CHOMP
279
280       Removes whitespace before/after directives (default: 0/0).
281
282       TRIM
283
284       Remove leading and trailing whitespace from template output (default:
285       0).
286
287       INTERPOLATE
288
289       Interpolate variables embedded like $this or "${this}" (default: 0).
290
291       ANYCASE
292
293       Allow directive keywords in lower case (default: 0 - UPPER only).
294
295   Template Files and Blocks
296       INCLUDE_PATH
297
298       One or more directories to search for templates.
299
300       DELIMITER
301
302       Delimiter for separating paths in "INCLUDE_PATH" (default: '":"').
303
304       ABSOLUTE
305
306       Allow absolute file names, e.g. "/foo/bar.html" (default: 0).
307
308       RELATIVE
309
310       Allow relative filenames, e.g. "../foo/bar.html" (default: 0).
311
312       DEFAULT
313
314       Default template to use when another not found.
315
316       BLOCKS
317
318       Hash array pre-defining template blocks.
319
320       AUTO_RESET
321
322       Enabled by default causing "BLOCK" definitions to be reset each time a
323       template is processed.  Disable to allow "BLOCK" definitions to
324       persist.
325
326       RECURSION
327
328       Flag to permit recursion into templates (default: 0).
329
330   Template Variables
331       VARIABLES
332
333       Hash array of variables and values to pre-define in the stash.
334
335   Runtime Processing Options
336       EVAL_PERL
337
338       Flag to indicate if "PERL"/"RAWPERL" blocks should be processed
339       (default: 0).
340
341       PRE_PROCESS, POST_PROCESS
342
343       Name of template(s) to process before/after main template.
344
345       PROCESS
346
347       Name of template(s) to process instead of main template.
348
349       ERROR
350
351       Name of error template or reference to hash array mapping error types
352       to templates.
353
354       OUTPUT
355
356       Default output location or handler.
357
358       OUTPUT_PATH
359
360       Directory into which output files can be written.
361
362       DEBUG
363
364       Enable debugging messages.
365
366   Caching and Compiling Options
367       CACHE_SIZE
368
369       Maximum number of compiled templates to cache in memory (default: undef
370       - cache all)
371
372       COMPILE_EXT
373
374       Filename extension for compiled template files (default: undef - don't
375       compile).
376
377       COMPILE_DIR
378
379       Root of directory in which compiled template files should be written
380       (default: undef - don't compile).
381
382   Plugins and Filters
383       PLUGINS
384
385       Reference to a hash array mapping plugin names to Perl packages.
386
387       PLUGIN_BASE
388
389       One or more base classes under which plugins may be found.
390
391       LOAD_PERL
392
393       Flag to indicate regular Perl modules should be loaded if a named
394       plugin can't be found  (default: 0).
395
396       FILTERS
397
398       Hash array mapping filter names to filter subroutines or factories.
399
400   Customisation and Extension
401       LOAD_TEMPLATES
402
403       List of template providers.
404
405       LOAD_PLUGINS
406
407       List of plugin providers.
408
409       LOAD_FILTERS
410
411       List of filter providers.
412
413       TOLERANT
414
415       Set providers to tolerate errors as declinations (default: 0).
416
417       SERVICE
418
419       Reference to a custom service object (default: Template::Service).
420
421       CONTEXT
422
423       Reference to a custom context object (default: Template::Context).
424
425       STASH
426
427       Reference to a custom stash object (default: Template::Stash).
428
429       PARSER
430
431       Reference to a custom parser object (default: Template::Parser).
432
433       GRAMMAR
434
435       Reference to a custom grammar object (default: Template::Grammar).
436

DIRECTIVE SUMMARY

438       The following list gives a short summary of each Template Toolkit
439       directive.  See Template::Manual::Directives for full details.
440
441   GET
442       Evaluate and print a variable or value.
443
444           [%   GET variable %]    # 'GET' keyword is optional
445           [%       variable %]
446           [%       hash.key %]
447           [%         list.n %]
448           [%     code(args) %]
449           [% obj.meth(args) %]
450           [%  "value: $var" %]
451
452   CALL
453       As per GET but without printing result (e.g. call code)
454
455           [%  CALL variable %]
456
457   SET
458       Assign a values to variables.
459
460           [% SET variable = value %]    # 'SET' also optional
461           [%     variable = other_variable
462                  variable = 'literal text @ $100'
463                  variable = "interpolated text: $var"
464                  list     = [ val, val, val, val, ... ]
465                  list     = [ val..val ]
466                  hash     = { var => val, var => val, ... }
467           %]
468
469   DEFAULT
470       Like SET, but variables are only set if currently unset (i.e. have no
471       true value).
472
473           [% DEFAULT variable = value %]
474
475   INSERT
476       Insert a file without any processing performed on the contents.
477
478           [% INSERT legalese.txt %]
479
480   PROCESS
481       Process another template file or block and insert the generated output.
482       Any template BLOCKs or variables defined or updated in the "PROCESS"ed
483       template will thereafter be defined in the calling template.
484
485           [% PROCESS template %]
486           [% PROCESS template  var = val, ... %]
487
488   INCLUDE
489       Similar to "PROCESS", but using a local copy of the current variables.
490       Any template "BLOCK"s or variables defined in the "INCLUDE"d template
491       remain local to it.
492
493           [% INCLUDE template %]
494           [% INCLUDE template  var = val, ... %]
495
496   WRAPPER
497       The content between the "WRAPPER" and corresponding "END" directives is
498       first evaluated, with the output generated being stored in the
499       "content" variable.  The named template is then process as per
500       "INCLUDE".
501
502           [% WRAPPER layout %]
503              Some template markup [% blah %]...
504           [% END %]
505
506       A simple layout template might look something like this:
507
508           Your header here...
509           [% content %]
510           Your footer here...
511
512   BLOCK
513       Define a named template block for INCLUDE, PROCESS and WRAPPER to use.
514
515           [% BLOCK hello %]
516              Hello World
517           [% END %]
518
519           [% INCLUDE hello %]
520
521   FOREACH
522       Repeat the enclosed "FOREACH" ... "END" block for each value in the
523       list.
524
525           [% FOREACH variable IN [ val, val, val ] %]    # either
526           [% FOREACH variable IN list %]                 # or
527              The variable is set to [% variable %]
528           [% END %]
529
530   WHILE
531       The block enclosed between "WHILE" and "END" block is processed while
532       the specified condition is true.
533
534           [% WHILE condition %]
535              content
536           [% END %]
537
538   IF / UNLESS / ELSIF / ELSE
539       The enclosed block is processed if the condition is true / false.
540
541           [% IF condition %]
542              content
543           [% ELSIF condition %]
544            content
545           [% ELSE %]
546            content
547           [% END %]
548
549           [% UNLESS condition %]
550              content
551           [% # ELSIF/ELSE as per IF, above %]
552              content
553           [% END %]
554
555   SWITCH / CASE
556       Multi-way switch/case statement.
557
558           [% SWITCH variable %]
559           [%   CASE val1 %]
560                  content
561           [%   CASE [ val2, val3 ] %]
562                  content
563           [%   CASE %]         # or [% CASE DEFAULT %]
564                  content
565           [% END %]
566
567   MACRO
568       Define a named macro.
569
570           [% MACRO name <directive> %]
571           [% MACRO name(arg1, arg2) <directive> %]
572           ...
573           [% name %]
574           [% name(val1, val2) %]
575
576   FILTER
577       Process enclosed "FILTER" ... "END" block then pipe through a filter.
578
579           [% FILTER name %]                       # either
580           [% FILTER name( params ) %]             # or
581           [% FILTER alias = name( params ) %]     # or
582              content
583           [% END %]
584
585   USE
586       Load a plugin module (see "Template::<Manual::Plugins"), or any regular
587       Perl module when the "LOAD_PERL" option is set.
588
589           [% USE name %]                      # either
590           [% USE name( params ) %]            # or
591           [% USE var = name( params ) %]      # or
592           ...
593           [% name.method %]
594           [% var.method %]
595
596   PERL / RAWPERL
597       Evaluate enclosed blocks as Perl code (requires the "EVAL_PERL" option
598       to be set).
599
600           [% PERL %]
601            # perl code goes here
602            $stash->set('foo', 10);
603            print "set 'foo' to ", $stash->get('foo'), "\n";
604            print $context->include('footer', { var => $val });
605           [% END %]
606
607           [% RAWPERL %]
608              # raw perl code goes here, no magic but fast.
609              $output .= 'some output';
610           [% END %]
611
612   TRY / THROW / CATCH / FINAL
613       Exception handling.
614
615           [% TRY %]
616            content
617              [% THROW type info %]
618           [% CATCH type %]
619            catch content
620              [% error.type %] [% error.info %]
621           [% CATCH %] # or [% CATCH DEFAULT %]
622            content
623           [% FINAL %]
624              this block is always processed
625           [% END %]
626
627   NEXT
628       Jump straight to the next item in a "FOREACH" or "WHILE" loop.
629
630           [% NEXT %]
631
632   LAST
633       Break out of "FOREACH" or "WHILE" loop.
634
635           [% LAST %]
636
637   RETURN
638       Stop processing current template and return to including templates.
639
640           [% RETURN %]
641
642   STOP
643       Stop processing all templates and return to caller.
644
645           [% STOP %]
646
647   TAGS
648       Define new tag style or characters (default: "[%" "%]").
649
650           [% TAGS html %]
651           [% TAGS <!-- --> %]
652
653   COMMENTS
654       Ignored and deleted.
655
656           [% # this is a comment to the end of line
657              foo = 'bar'
658           %]
659
660           [%# placing the '#' immediately inside the directive
661               tag comments out the entire directive
662           %]
663

SOURCE CODE REPOSITORY

665       The source code for the Template Toolkit is held in a public git
666       repository on Github: <https://github.com/abw/Template2>
667

AUTHOR

669       Andy Wardley <abw@wardley.org> <http://wardley.org/>
670

VERSION

672       Template Toolkit version 3.010, released on July 13 2020.
673

SUPPORT

675       The Template Toolkit mailing list provides a forum for discussing
676       issues relating to the use and abuse of the Template Toolkit.  There
677       are a number of knowledgeable and helpful individuals who frequent the
678       list (including the author) who can often offer help or suggestions.
679       Please respect their time and patience by checking the documentation
680       and/or mailing list archives before asking questions that may already
681       have been answered.
682
683       To subscribe to the mailing list, send an email to:
684
685           template-toolkit+subscribe@groups.io
686
687       You can also use the web interface:
688
689           https://groups.io/g/template-toolkit
690
691       For information about commercial support and consultancy for the
692       Template Toolkit, please contact the author.
693
695       Copyright (C) 1996-2020 Andy Wardley.  All Rights Reserved.
696
697       This module is free software; you can redistribute it and/or modify it
698       under the same terms as Perl itself.
699
700
701
702perl v5.36.0                      2022-07-22                       Template(3)
Impressum