NAME
Bolts::Util - Utilities helpful for use with Bolts
VERSION
version 0.143171
SYNOPSIS
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.