NAME
MooseX::AbstractFactory::Role - AbstractFactory behaviour as a Moose extension
VERSION
version 0.004001
SYNOPSIS
You shouldn't be using this on its own, but via MooseX::AbstractFactory
DESCRIPTION
Role to implement an AbstractFactory as a Moose extension.
METHODS
create()
Returns an instance of the requested implementation.
use MooseX::AbstractFactory;
my $imp = My::Factory->create(
'Implementation',
{ connection => 'Type1' },
);
_validate_implementation_class()
Checks that the implementation class exists (via Class::MOP->load_class() ) to be used, and (optionally) that it provides the methods defined in _roles().
This can be overridden by a factory class definition if required: for example
sub _validate_implementation_class {
my $self = shift;
return 1; # all implementation classes are valid :)
}
_get_implementation_class()
By default, the factory figures out the class of the implementation requested by prepending the factory class itself, so for example
my $imp = My::Factory->new(
implementation => 'Implementation')
will return an object of class My::Factory::Implementation.
This can be overridden in the factory class by redefining the _get_implementation_class() method, for example:
sub _get_implementation_class {
my ($self, $class) = @_;
return "My::ImplementationClasses::$class";
}
BUGS AND LIMITATIONS
No bugs have been reported. Yet.
Please report any bugs or feature requests to mike@altrion.org
, or via RT.
ACKNOWLEDGMENTS
Thanks to Matt Trout for some of the ideas for the code in _validate_implementation_class.
BUGS
Please report any bugs or feature requests on the bugtracker website https://github.com/fleetfootmike/MX-AbstractFactory/issues
When submitting a bug or request, please include a test-file or a patch to an existing test-file that illustrates the bug or desired feature.
AUTHORS
Mike Whitaker <mike@altrion.org>
Caleb Cushing <xenoterracide@gmail.com>
COPYRIGHT AND LICENSE
This software is copyright (c) 2012 by Mike Whitaker.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.