use Carp 'confess';
use Scalar::Util 'reftype', 'blessed';
-use B 'svref_2object';
+#use B 'svref_2object';
our $VERSION = '0.05';
our $AUTHORITY = 'cpan:STEVAN';
# associated with the actual CODE-ref
sub package_name {
my $code = (shift)->body;
- svref_2object($code)->GV->STASH->NAME;
+ (Class::MOP::get_code_info($code))[0];
}
# NOTE:
# with the actual CODE-ref
sub name {
my $code = (shift)->body;
- svref_2object($code)->GV->NAME;
+ (Class::MOP::get_code_info($code))[1];
}
sub fully_qualified_name {
Class::MOP::Method - Method Meta Object
-=head1 SYNOPSIS
-
- # ... more to come later maybe
-
=head1 DESCRIPTION
The Method Protocol is very small, since methods in Perl 5 are just
=over 4
-=item B<wrap (&code)>
+=item B<wrap ($code)>
+
+This is the basic constructor, it returns a B<Class::MOP::Method>
+instance which wraps the given C<$code> reference.
=back
=item B<body>
+This returns the actual CODE reference of the particular instance.
+
=item B<name>
+This returns the name of the CODE reference.
+
=item B<package_name>
+This returns the package name that the CODE reference is attached to.
+
=item B<fully_qualified_name>
+This returns the fully qualified name of the CODE reference.
+
=back
=head1 AUTHORS
Stevan Little E<lt>stevan@iinteractive.comE<gt>
-Yuval Kogman E<lt>nothingmuch@woobling.comE<gt>
-
=head1 COPYRIGHT AND LICENSE
-Copyright 2006 by Infinity Interactive, Inc.
+Copyright 2006-2008 by Infinity Interactive, Inc.
L<http://www.iinteractive.com>