The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.

NAME

Starch::Plugin::Bundle - Base role for Starch plugin bundles.

SYNOPSIS

    # Create a bundle.
    package MyDevPlugins;
    use Moo;
    with 'Starch::Plugin::Bundle';
    sub bundled_plugins {
        return ['::Trace', 'MyApp::Starch::CustomPLugin'];
    }

    # Use the bundle.
    my $starch = Starch->new(
        plugins => ['MyDevPlugin'],
        ...,
    );

DESCRIPTION

Plugin bundles package together any number of other plugins and plugin bundles. To create a plugin bundle just make a new class that consumes this role and defines the bundled_plugins method. This method should return an array ref of plugin names (absolute or relative).

See "PLUGINS" in Starch::Extending for more information.

ATTRIBUTES

plugins

This returns the array ref of plugins provided by the bundled_plugins method.

resolved_plugins

This returns "plugins" with all relative plugin names made absolute.

roles

Returns "resolved_plugins" with all plugin bundles expanded to their roles.

manager_roles

Of the "roles" this returns the ones that consume the Starch::Plugin::ForManager role.

state_roles

Of the "roles" this returns the ones that consume the Starch::Plugin::ForState role.

store_roles

Of the "roles" this returns the ones that consume the Starch::Plugin::ForStore role.

AUTHORS AND LICENSE

See "AUTHOR" in Starch, "CONTRIBUTORS" in Starch, and "LICENSE" in Starch.