use strict;
use warnings;
-our $VERSION = '1.13';
-$VERSION = eval $VERSION;
-our $AUTHORITY = 'cpan:STEVAN';
+use Class::MOP::MiniTrait;
use base 'Class::MOP::Method';
+Class::MOP::MiniTrait::apply(__PACKAGE__, 'Moose::Meta::Object::Trait');
+
sub _error_thrower {
my $self = shift;
+ require Moose::Meta::Class;
( ref $self && $self->associated_metaclass ) || "Moose::Meta::Class";
}
sub _inline_throw_error {
my ( $self, $msg, $args ) = @_;
- "\$meta->throw_error($msg" . ($args ? ", $args" : "") . ")"; # FIXME makes deparsing *REALLY* hard
+
+ my $inv = $self->_error_thrower;
+ # XXX ugh
+ $inv = 'Moose::Meta::Class' unless $inv->can('_inline_throw_error');
+
+ # XXX ugh ugh UGH
+ my $class = $self->associated_metaclass;
+ if ($class) {
+ my $class_name = B::perlstring($class->name);
+ my $meth_name = B::perlstring($self->name);
+ $args = 'method => Class::MOP::class_of(' . $class_name . ')'
+ . '->find_method_by_name(' . $meth_name . '), '
+ . (defined $args ? $args : '');
+ }
+
+ return $inv->_inline_throw_error($msg, $args)
}
1;
+# ABSTRACT: A Moose Method metaclass
+
__END__
=pod
-=head1 NAME
-
-Moose::Meta::Method - A Moose Method metaclass
-
=head1 DESCRIPTION
This class is a subclass of L<Class::MOP::Method> that provides
See L<Moose/BUGS> for details on reporting bugs.
-=head1 AUTHOR
-
-Stevan Little E<lt>stevan@iinteractive.comE<gt>
-
-=head1 COPYRIGHT AND LICENSE
-
-Copyright 2006-2010 by Infinity Interactive, Inc.
-
-L<http://www.iinteractive.com>
-
-This library is free software; you can redistribute it and/or modify
-it under the same terms as Perl itself.
-
=cut