package Moose::Meta::Role::Application::ToInstance; BEGIN { $Moose::Meta::Role::Application::ToInstance::AUTHORITY = 'cpan:STEVAN'; } $Moose::Meta::Role::Application::ToInstance::VERSION = '2.1204'; use strict; use warnings; use metaclass; use Scalar::Util 'blessed'; use List::MoreUtils 'all'; use parent 'Moose::Meta::Role::Application'; __PACKAGE__->meta->add_attribute('rebless_params' => ( reader => 'rebless_params', default => sub { {} }, Class::MOP::_definition_context(), )); 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 => (all { $_ eq '-alias' || $_ eq '-excludes' } keys %$args), ); $class->rebless_instance( $object, %{ $self->rebless_params } ); } 1; # ABSTRACT: Compose a role into an instance __END__ =pod =encoding UTF-8 =head1 NAME Moose::Meta::Role::Application::ToInstance - Compose a role into an instance =head1 VERSION version 2.1204 =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 AUTHORS =over 4 =item * Stevan Little =item * Dave Rolsky =item * Jesse Luehrs =item * Shawn M Moore =item * יובל קוג'מן (Yuval Kogman) =item * Karen Etheridge =item * Florian Ragwitz =item * Hans Dieter Pearcey =item * Chris Prather =item * Matt S Trout =back =head1 COPYRIGHT AND LICENSE This software is copyright (c) 2006 by Infinity Interactive, Inc.. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself. =cut