NAME
Bolts::Util - Utilities helpful for use with Bolts
VERSION
version 0.143171
SYNOPSIS
use Bolts::Util qw( bolts_init locator_for meta_locator_for );
my $loc = locator_for($bag);
my $thing = $loc->acquire('path', 'to', 'thing');
my $metaloc = meta_locator_for($bag);
my $blueprint = $metaloc->acquire('blueprint', 'factory', {
class => 'MyApp::Thing',
method => 'fetch',
});
# See Bolts::Role::Initializer for a better synopsis
my $obj = MyApp::Thing->new(
foo => bolts_init('path', 'to', 'foo'),
);
DESCRIPTION
This provides some helpful utility methods for use with Bolts.
EXPORTED FUNCTIONS
artifact
my %artifact = %{ artifact($bag, $name, %definition) };
# For example:
my %artifact = %{ artifact($bag, thing => ( class => 'MyApp::Thing' ) ) };
This contains the internal implementation for building Bolt::Artifact objects used by the sugar methods in Bolts and Bolts::Role. See the documentation there for more details on how to call it.
The $bag
must be the metaclass or reference to which the artifact is being attached. The $name
is the name to give the artifact and teh %definition
is the remainder of the definition.
This function returns a hash with a single key, which is the name of the artifact. The value on that key is an object that implements Bolts::Role::Artifact.
locator_for
my $loc = locator_for($bag);
Given a bag, it will return a Bolts::Role::Locator for acquiring artifacts from it. If the bag provides it's own locator, the bag will be returned. If it doesn't (e.g., if it's a hash or an array or just some other object that doesn't have a locator built-in), then a new locator will be built to locate within the bag and returned on the first call. Subsequent calls using the same reference will return the same locator object.
meta_locator_for
my $metaloc = meta_locator_for($bag);
Attempts to find the meta locator for the bag. It returns a Bolts::Role::Locator that is able to return artifacts used to manage a collection of bolts bags and artifacts. If the bag itself does not have such a locator associated with it, one is constructed using the "$Bolts::GLOBAL_FALLBACK_META_LOCATOR" in Bolts class, which is Bolts::Meta::Locator by default. After the first call, the object created the first time for each reference will be reused.
bolts_init
my $init = bolts_init(@path, \%params);
This is shorthand for:
my $init = Bolts::Meta::Initializer->new(@path, \%params);
This returns an initializer object that may be used with Bolts::Role::Initializer to automatically initialize attributes from a built-in locator.
AUTHOR
Andrew Sterling Hanenkamp <hanenkamp@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2014 by Qubling Software LLC.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.