NAME
Iterator::Flex::Role::Utils - Role based utilities
VERSION
version 0.13
DESCRIPTION
This is a Role::Tiny
role which adds a variety of utility methods to a class. They are structured that way so that they may be overridden if necessary. (Well, technically under-ridden if they already exist before this role is applied).
METHODS
_load_module
$module = $class->_load_module( @path );
Search through the namespaces provided by $class->_namespaces
to load the module whose name is given by
$class->_module_name( $namespace, @path );
Throws Iterator::Flex::Failure::class
if it couldn't require the module (for whatever reason).
_load_role
$module = $class->_load_role( $role );
Loads the named role. If the name begins with a +
, it is assumed to be a fully qualified name, otherwise it is searched for in the namespaces returned by the _role_namespaces
class method.
_can_meth
$code = $class->_can_meth( @methods, ?\%pars );
$code = $class->_can_meth( $obj, @method, ?\%pars );
Scans an object to see if it provides one of the specified methods. For each $method
in @methods
, it probes for __$method__
, then $method
.
By default, it returns a reference to the first method it finds, otherwise undef
if none was found.
The return value can be altered using %pars
.
- name
-
return the name of the method.
- code
-
return the coderef of the method. (Default)
If both code
and name
are specified, both are returned as a list, name
first:
($name, $code ) = $class->_can_meth( $obj, @methods, {name => 1, code => 1 } );
_resolve_meth
$code = $obj->_resolve_meth( $target, $method, @fallbacks );
Return a coderef to the specified method or one of the fallbacks.
If $method
is a coderef, it is returned.
If $method
is defined and is not a coderef, it is checked for directly via $target-
can>. If it does not exist, a Iterator::Flex::Failure::parameter
error is thrown.
If $method
is not defined, then $obj->_can_meth( $target, @fallbacks )
is returned.
_throw
$obj->_throw( $type => $message );
Throw an exception object of class Iterator::Flex::Failure::$type
with the given message.
SUPPORT
Bugs
Please report any bugs or feature requests to bug-iterator-flex@rt.cpan.org or through the web interface at: https://rt.cpan.org/Public/Dist/Display.html?Name=Iterator-Flex
Source
Source is available at
https://gitlab.com/djerius/iterator-flex
and may be cloned from
https://gitlab.com/djerius/iterator-flex.git
SEE ALSO
Please see those modules/websites for more information related to this module.
AUTHOR
Diab Jerius <djerius@cpan.org>
COPYRIGHT AND LICENSE
This software is Copyright (c) 2018 by Smithsonian Astrophysical Observatory.
This is free software, licensed under:
The GNU General Public License, Version 3, June 2007