NAME
MooseX::ClassCompositor - a factory that builds classes from roles
VERSION
version 0.004
SYNOPSIS
my $comp = MooseX::ClassCompositor->new({
class_basename => 'MyApp::Class',
class_metaroles => {
class => [ 'MooseX::StrictConstructor::Trait::Class' ],
},
role_prefixes => {
'' => 'MyApp::Role::',
'=' => '',
},
});
my $class = $comp->class_for( qw( PieEater ContestWinner ) );
my $object = $class->new({
pie_type => 'banana',
place => '2nd',
});
OVERVIEW
A MooseX::ClassCompositor is a class factory. If you think using a class factory will make you feel like a filthy "enterprise" programmer, maybe you should turn back now.
The compositor has a "class_for"
method that builds a class by combining a list of roles with Moose::Object, applying any supplied metaclass, and producing an arbitrary-but-human-scannable name. The metaclass is then made immutable, the operation is memoized, and the class name is returned.
In the "SYNOPSIS" above, you can see all the major features used: class_metaroles
to enable strict constructors, role_prefixes
to use String::RewritePrefix to expand role name shorthand, and class_basename
to pick a namespace under which to put constructed classes.
Not shown is the "known_classes"
method, which returns a list of pairs describing all the classes that the factory has constructed. This method can be useful for debugging and other somewhat esoteric purposes like serialization.
ATTRIBUTES
class_basename
This attribute must be given, and must be a valid Perl package name. Constructed classes will all be under this namespace.
class_metaroles
This attribute, if given, must be a hashref of class metaroles that will be applied to newly-constructed classes with Moose::Util::MetaRole::apply_metaroles.
known_classes
This attribute stores a mapping of class names to the parameters used to construct them. The known_classes
method returns its contents as a list of pairs.
role_prefixes
This attribute is used as the arguments to String::RewritePrefix for expanding role names passed to the compositor's class_for method.
fixed_roles
This attribute may be initialized with an arrayref of role names. These roles will always be composed in the classes built by the compositor.
These names will be rewritten by the role prefixes.
METHODS
class_for
my $class = $compositor->class_for(
'Role::Name', # <-- will be expanded with role_prefixes
[
'Param::Role::Name', # <-- will be expanded with role_prefixes
'ApplicationName', # <-- will not be touched
{ ...param... },
],
);
This method will return a class with the roles passed to it. They can be given either as names (which will be expanded according to "role_prefixes"
) or as arrayrefs containing a role name, application name, and hashref of parameters. In the arrayref form, the application name is just a name used to uniquely identify this application of a parameterized role, so that they can be applied multiple times with each application accounted for internally.
Note that at present, passing Moose::Meta::Role objects is not supported. This should change in the future.
THANKS
Thanks to Pobox.com for sponsoring the development of this library.
AUTHORS
Ricardo Signes <rjbs@cpan.org>
Mark Jason Dominus <mjd@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2011 by Ricardo Signes.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.