Sponsoring The Perl Toolchain Summit 2025: Help make this important event another success Learn more

NAME

Footprintless::Plugin - The base class for footprintless plugins

VERSION

version 1.29

DESCRIPTION

This class serves as a base class for plugins. It defines the mandatory interface that a plugin must implement. Plugins add methods to the factory itself at runtime. For example:

package Foo::Plugin;
sub foo {
require Foo;
return Foo->new();
}
sub factory_methods {
my ($self) = @_;
return {
foo => sub {
return $self->foo(@_);
}
}
}
package Foo;
sub new() {
return bless({}, shift);
}
sub bar {
print("BAR");
}

Then they can be registered with a factory instance:

$factory->register_plugin(Foo::Plugin->new());

Or, they can be registered via configuration in the footprintless.plugins entity:

# $FPL_HOME/config/footprintless.pm
return {
plugins => [
'Foo::Plugin',
'Bar::Plugin'
],
'Foo::Plugin' => {
# optional config
}
'Bar::Plugin' => {
# optional config
}
};

Then you can use the methods directly on the footprintless instance:

my $footprintless = Footprintless->new();
my $foo = $footprintless->foo();

If a key with the same name as the plugin is present in the footprintless entity, then the entire hashref will be set as $self-{config}> on the plugin instance during construction. You can then override the _init() method to do configuration based initialization.

If you want to add commands, just add a module under the package returned by command_packages (defaults to ref($self) . '::Command'):

use Footprintless::App -command;
sub execute {
my ($self, $opts, $args) = @_;
my $foo = $self->app()->footprintless()->foo();
$foo->bar();
}

Then your command will be availble from the fpl command:

$> fpl foo
BAR

CONSTRUCTORS

new()

Creates a new plugin.

METHODS

command_packages()

Returns a list of packages to scan for commands.

factory_methods()

Returns a hash full of factory methods. The key will be used as the method name that gets registered with the factory. Its value must be a reference to a sub.

AUTHOR

Lucas Theisen <lucastheisen@pastdev.com>

COPYRIGHT AND LICENSE

This software is copyright (c) 2016 by Lucas Theisen.

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

SEE ALSO

Please see those modules/websites for more information related to this module.