NAME

Module::Pluggable::Singleton - call/return single plugins on demand using shortened names

VERSION

version 0.04

SYNOPSIS

package MyPluggable;
use Module::Pluggable::Singleton;

my $plugins = MyPluggable->plugin;
my @plugins = MyPluggable->plugin;

my @plugins = MyPluggable->plugins;

my $plugin_long = $logic->plugin($name);

my $plugins = MyPluggable->plugin;
my $nick = MyPluggable->call('Robert','nickname',$person->full_name);

DESCRIPTION

METHODS

find($name)

Return the instance of the plugin with given short name

$plugin = $logic->find('Bar');

plugin($name)

Return an array of the shortened available plugins or the full name of the module when a short name is given

my @plugin_short = $logic->plugin
my $plugin_long = $logic->plugin($name);

plugin($name)

Return an array of all the module names

call($plugin_name, $method, $params)

Using the plugin $plugin_name call $method with $params

$rv = $logic->call($plugin_name, $method, $params)

AUTHOR

Jason Tang, <tang.jason.ch at gmail.com>

BUGS

Please report any bugs or feature requests to bug-module-pluggable-singleton at rt.cpan.org, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Module-Pluggable-Singleton. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.

SEE ALSO

Module::Pluggable::Object

SUPPORT

You can find documentation for this module with the perldoc command.

perldoc Module::Pluggable::Singleton

You can also look for information at:

LICENSE AND COPYRIGHT

Copyright 2011 Jason Tang.

This program is free software; you can redistribute it and/or modify it under the terms of either: the GNU General Public License as published by the Free Software Foundation; or the Artistic License.

See http://dev.perl.org/licenses/ for more information.