1 package Moose::Meta::Method;
6 our $VERSION = '1.9900';
7 $VERSION = eval $VERSION;
8 our $AUTHORITY = 'cpan:STEVAN';
10 use Class::MOP::MiniTrait;
12 use base 'Class::MOP::Method';
14 Class::MOP::MiniTrait::apply(__PACKAGE__, 'Moose::Meta::Object::Trait');
18 ( ref $self && $self->associated_metaclass ) || "Moose::Meta::Class";
23 my $inv = $self->_error_thrower;
24 unshift @_, "message" if @_ % 2 == 1;
25 unshift @_, method => $self if ref $self;
27 my $handler = $inv->can("throw_error");
28 goto $handler; # to avoid incrementing depth by 1
31 sub _inline_throw_error {
32 my ( $self, $msg, $args ) = @_;
33 "\$meta->throw_error($msg" . ($args ? ", $args" : "") . ")"; # FIXME makes deparsing *REALLY* hard
44 Moose::Meta::Method - A Moose Method metaclass
48 This class is a subclass of L<Class::MOP::Method> that provides
49 additional Moose-specific functionality, all of which is private.
51 To understand this class, you should read the the L<Class::MOP::Method>
56 C<Moose::Meta::Method> is a subclass of L<Class::MOP::Method>.
60 See L<Moose/BUGS> for details on reporting bugs.
64 Stevan Little E<lt>stevan@iinteractive.comE<gt>
66 =head1 COPYRIGHT AND LICENSE
68 Copyright 2006-2010 by Infinity Interactive, Inc.
70 L<http://www.iinteractive.com>
72 This library is free software; you can redistribute it and/or modify
73 it under the same terms as Perl itself.