package Class::MOP::MiniTrait; BEGIN { $Class::MOP::MiniTrait::AUTHORITY = 'cpan:STEVAN'; } $Class::MOP::MiniTrait::VERSION = '2.1204'; use strict; use warnings; use Module::Runtime 'use_package_optimistically'; sub apply { my ( $to_class, $trait ) = @_; for ( grep { !ref } $to_class, $trait ) { use_package_optimistically($_); $_ = Class::MOP::Class->initialize($_); } for my $meth ( grep { $_->package_name ne 'UNIVERSAL' } $trait->get_all_methods ) { my $meth_name = $meth->name; if ( $to_class->find_method_by_name($meth_name) ) { $to_class->add_around_method_modifier( $meth_name, $meth->body ); } else { $to_class->add_method( $meth_name, $meth->clone ); } } } # We can't load this with use, since it may be loaded and used from Class::MOP # (via CMOP::Class, etc). However, if for some reason this module is loaded # _without_ first loading Class::MOP we need to require Class::MOP so we can # use it and CMOP::Class. require Class::MOP; 1; # ABSTRACT: Extremely limited trait application __END__ =pod =encoding UTF-8 =head1 NAME Class::MOP::MiniTrait - Extremely limited trait application =head1 VERSION version 2.1204 =head1 DESCRIPTION This package provides a single function, C, which does a half-assed job of applying a trait to a class. It exists solely for use inside Class::MOP and L core classes. =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