package Moose::Meta::Role::Application::ToInstance; use strict; use warnings; use metaclass; use Scalar::Util 'blessed'; our $VERSION = '1.25'; $VERSION = eval $VERSION; our $AUTHORITY = 'cpan:STEVAN'; use base 'Moose::Meta::Role::Application'; __PACKAGE__->meta->add_attribute('rebless_params' => ( reader => 'rebless_params', default => sub { {} } )); sub apply { my ( $self, $role, $object, $args ) = @_; my $obj_meta = Class::MOP::class_of($object) || 'Moose::Meta::Class'; # This is a special case to handle the case where the object's metaclass # is a Class::MOP::Class, but _not_ a Moose::Meta::Class (for example, # when applying a role to a Moose::Meta::Attribute object). $obj_meta = 'Moose::Meta::Class' unless $obj_meta->isa('Moose::Meta::Class'); my $class = $obj_meta->create_anon_class( superclasses => [ blessed($object) ], roles => [ $role, keys(%$args) ? ($args) : () ], cache => 1, ); $class->rebless_instance( $object, %{ $self->rebless_params } ); } 1; __END__ =pod =head1 NAME Moose::Meta::Role::Application::ToInstance - Compose a role into an instance =head1 DESCRIPTION =head2 METHODS =over 4 =item B =item B =item B =item B =back =head1 BUGS See L for details on reporting bugs. =head1 AUTHOR Stevan Little Estevan@iinteractive.comE =head1 COPYRIGHT AND LICENSE Copyright 2006-2010 by Infinity Interactive, Inc. L This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself. =cut