Template::Plugins man page on Fedora

Man page or keyword search:  
man Server   31170 pages
apropos Keyword Search (all sections)
Output format
Fedora logo
[printable version]

Template::Plugins(3)  User Contributed Perl Documentation Template::Plugins(3)

NAME
       Template::Plugins - Plugin provider module

SYNOPSIS
	   use Template::Plugins;

	   $plugin_provider = Template::Plugins->new(\%options);

	   ($plugin, $error) = $plugin_provider->fetch($name, @args);

DESCRIPTION
       The "Template::Plugins" module defines a provider class which can be
       used to load and instantiate Template Toolkit plugin modules.

METHODS
   new(\%params)
       Constructor method which instantiates and returns a reference to a
       "Template::Plugins" object.  A reference to a hash array of
       configuration items may be passed as a parameter.  These are described
       below.

       Note that the Template front-end module creates a "Template::Plugins"
       provider, passing all configuration items.  Thus, the examples shown
       below in the form:

	   $plugprov = Template::Plugins->new({
	       PLUGIN_BASE => 'MyTemplate::Plugin',
	       LOAD_PERL   => 1,
	       ...
	   });

       can also be used via the Template module as:

	   $ttengine = Template->new({
	       PLUGIN_BASE => 'MyTemplate::Plugin',
	       LOAD_PERL   => 1,
	       ...
	   });

       as well as the more explicit form of:

	   $plugprov = Template::Plugins->new({
	       PLUGIN_BASE => 'MyTemplate::Plugin',
	       LOAD_PERL   => 1,
	       ...
	   });

	   $ttengine = Template->new({
	       LOAD_PLUGINS => [ $plugprov ],
	   });

   fetch($name, @args)
       Called to request that a plugin of a given name be provided. The
       relevant module is first loaded (if necessary) and the load() class
       method called to return the factory class name (usually the same
       package name) or a factory object (a prototype).	 The new() method is
       then called as a class or object method against the factory, passing
       all remaining parameters.

       Returns a reference to a new plugin object or "($error, STATUS_ERROR)"
       on error.  May also return "(undef, STATUS_DECLINED)" to decline to
       serve the request.  If "TOLERANT" is set then all errors will be
       returned as declines.

CONFIGURATION OPTIONS
       The following list summarises the configuration options that can be
       provided to the "Template::Plugins" new() constructor.  Please consult
       Template::Manual::Config for further details and examples of each
       configuration option in use.

   PLUGINS
       The PLUGINS option can be used to provide a reference to a hash array
       that maps plugin names to Perl module names.

	   my $plugins = Template::Plugins->new({
	       PLUGINS => {
		   cgi => 'MyOrg::Template::Plugin::CGI',
		   foo => 'MyOrg::Template::Plugin::Foo',
		   bar => 'MyOrg::Template::Plugin::Bar',
	       },
	   });

   PLUGIN_BASE
       If a plugin is not defined in the PLUGINS hash then the PLUGIN_BASE is
       used to attempt to construct a correct Perl module name which can be
       successfully loaded.

	   # single value PLUGIN_BASE
	   my $plugins = Template::Plugins->new({
	       PLUGIN_BASE => 'MyOrg::Template::Plugin',
	   });

	   # multiple value PLUGIN_BASE
	   my $plugins = Template::Plugins->new({
	       PLUGIN_BASE => [	  'MyOrg::Template::Plugin',
				  'YourOrg::Template::Plugin'  ],
	   });

   LOAD_PERL
       The LOAD_PERL option can be set to allow you to load regular Perl
       modules (i.e. those that don't reside in the "Template::Plugin" or
       another user-defined namespace) as plugins.

       If a plugin cannot be loaded using the PLUGINS or PLUGIN_BASE
       approaches then, if the LOAD_PERL is set, the provider will make a
       final attempt to load the module without prepending any prefix to the
       module path.

       Unlike regular plugins, modules loaded using LOAD_PERL do not receive a
       Template::Context reference as the first argument to the "new()"
       constructor method.

   TOLERANT
       The TOLERANT flag can be set to indicate that the "Template::Plugins"
       module should ignore any errors encountered while loading a plugin and
       instead return "STATUS_DECLINED".

   DEBUG
       The DEBUG option can be used to enable debugging messages for the
       "Template::Plugins" module by setting it to include the "DEBUG_PLUGINS"
       value.

	   use Template::Constants qw( :debug );

	   my $template = Template->new({
	       DEBUG => DEBUG_FILTERS | DEBUG_PLUGINS,
	   });

TEMPLATE TOOLKIT PLUGINS
       Please see Template::Manual::Plugins For a complete list of all the
       plugin modules distributed with the Template Toolkit.

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

COPYRIGHT
       Copyright (C) 1996-2007 Andy Wardley.  All Rights Reserved.

       This module is free software; you can redistribute it and/or modify it
       under the same terms as Perl itself.

SEE ALSO
       Template::Manual::Plugins, Template::Plugin, Template::Context,
       Template.

perl v5.14.3			  2012-01-21		  Template::Plugins(3)
[top]

List of man pages available for Fedora

Copyright (c) for man pages and the logo by the respective OS vendor.

For those who want to learn more, the polarhome community provides shell access and support.

[legal] [privacy] [GNU] [policy] [cookies] [netiquette] [sponsors] [FAQ]
Tweet
Polarhome, production since 1999.
Member of Polarhome portal.
Based on Fawad Halim's script.
....................................................................
Vote for polarhome
Free Shell Accounts :: the biggest list on the net