NAME
Text::Tmpl - Templating system perl library
SYNOPSIS
use Text::Tmpl;
$context = new Text::Tmpl;
$return = $context->set_delimiters($opentag, $closetag);
$return = $context->register_simple($name, $coderef);
$return = $context->register_pair($isnamed, $open_name, $close_name, $coderef);
$return = $context->alias_simple($old_name, $new_name);
$return = $context->alias_pair($old_open_name, $old_close_name, $new_open_name, $new_close_name);
$context->remove_simple($name);
$context->remove_pair($open_name);
$context->set_debug($to_debug_or_not_to_debug);
$context->set_strip($to_strip_or_not_to_strip);
$return = $context->set_dir($directory);
$return = $context->set_value($name, $value);
$return = $context->set_values($hashref);
$subcontext = $context->loop_iteration($loop_name);
$subcontext = $context->fetch_loop_iteration($loop_name, $iteration_number);
$output = $context->parse_file($template_filename);
$output = $context->parse_string($template);
$errno = Text::Tmpl::errno();
$errstr = Text::Tmpl::strerror();
DESCRIPTION
Design goals
simplicity, reusability, speed, complete separation of logic from formatting.
Feature set
variables, loops, conditionals, extensibility of tags, includes, arbitrary delimiters.
Usage
For starters, make sure you 'use Text::Tmpl'.
Each function is described below:
- new
-
This function initializes the library. It allocates and returns the "global" context structure, and also configures all of the default tag behavior.
- set_delimiters
-
This function lets you change the delimiters marking the beginning and end of a tag (by default, these are "<!--#" and "-->"), for the specified context.
- set_value
-
This function stores the name=value pair in the current context.
- set_values
-
This function dumps the name=value pairs from a hash reference into the current context.
- set_debug
-
This function turns debugging output on or off. Note that debugging output hasn't been written yet - this is just a placeholder.
- set_strip
-
This function enables or disables the newline stripping feature. If enabled, the parser removes a single newline (if present) from after any tag.
- set_dir
-
This function sets the directory where templates will be sought, both by parse_file and by the include tag. Search order is always current directory then this searched directory.
This directory must contain all the necessary punctuation so that appending a filename to it produces a valid path (On unix systems, you have to include the trailing slash on the directory name).
- loop_iteration
-
This function adds an iteration to the loop named loop_name, and returns a unique context for that loop iteration.
- fetch_loop_iteration
-
This function retrieves and returns the context for $iteration_number from the loop named $loop_name.
- parse_file
-
This function opens $template_filename, and parses the contents of that file as a template, returning the output.
- parse_string
-
This function parses template directly, in the same way that Text::Tmpl::parse_file does.
- register_simple
-
This function registers a new simple tag named $name, which when encountered will cause the parser to call $coderef. See template_extend(1) for the gory details.
- register_pair
-
This function registers a new tag pair $open_name/$close_name, which when encountered will cause the parser to call $coderef. See template_extend for the gory details.
- alias_simple
-
This function copies the definition of a simple tag, previously registered as $old_name, to also be called by $new_name.
- alias_pair
-
This function copies the definition of a tag pair, previously registered as $old_open_name/$old_close_name, to also be called by $new_open_name/$new_close_name.
- remove_simple
-
This function removes the simple tag $name.
- remove_pair
-
This function removes the tag pair whose open tag is $open_name.
- errno
-
This function returns the error number of the last error - see the RETURN VALUES section below.
- strerror
-
This function returns a string describing the last error - see the RETURN VALUES section below.
RETURN VALUES
All of the above functions which return numeric values will return 0 if they fail, or 1 otherwise. The ones which return contexts will return undef if they fail, or a valid pointer otherwise.
A function which fails will also set a global error number, which you can read using the errno() or strerror() package functions.
BUGS
Hopefully none.
AUTHOR
J. David Lowe, dlowe@pootpoot.com
SEE ALSO
libtmpl(1), template_syntax(1), template_extend(1)