NAME
MooseX::LexicalRoleApplication - Apply roles for a lexical scope only
VERSION
version 0.03
SYNOPSIS
my
$obj
= SomeClass->new;
$obj
->method_from_role;
# fails
{
my
$guard
= MooseX::LexicalRoleApplication->apply(SomeRole->meta,
$obj
);
$obj
->method_from_role;
# works
}
$obj
->method_from_role;
# fails
DESCRIPTION
This module allows applying a role for the duration of a lexical scope only.
CAVEATS
Actual lexical role application isn't quite supported yet. The following example won't do what it's supposed to just yet:
{
my
$guard
= MooseX::LexicalRoleApplication->apply(
$role
,
$obj
);
$other_role
->apply(
$obj
);
}
METHODS
apply ($role, $instance, \%rebless_params, \%application_options)
Will apply $role
to $instance
. %rebless_params
will be passed to "rebless_instance" in Class::MOP::Class. %application_options
will be passed to "apply" in Moose::Meta::Role.
A Scope::Guard will be returned. Keep it around as long as you want $role
to be applied to $instance
. You can cancel role removal by calling dismiss
on the returned scope guard. If you want to remove the role immediately, you can simply undef the guard.
AUTHOR
Florian Ragwitz <rafl@debian.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2010 by Florian Ragwitz.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.