X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FClass%2FMOP%2FPackage.pm;h=1caf033db8b29b97c85c84a12361f52d2cbf72ee;hb=88b8ac17305b1bf7f1795337d7d443aec0bd3057;hp=7a64096e400727425b127ff0f275dabb80f40367;hpb=33f5d8ecd0e065b90c6e4763c1933cd108bb8509;p=gitmo%2FClass-MOP.git diff --git a/lib/Class/MOP/Package.pm b/lib/Class/MOP/Package.pm index 7a64096..1caf033 100644 --- a/lib/Class/MOP/Package.pm +++ b/lib/Class/MOP/Package.pm @@ -7,7 +7,7 @@ use warnings; use Scalar::Util 'blessed'; use Carp 'confess'; -our $VERSION = '0.64_02'; +our $VERSION = '0.70_01'; $VERSION = eval $VERSION; our $AUTHORITY = 'cpan:STEVAN'; @@ -27,15 +27,15 @@ sub initialize { # we hand-construct the class # until we can bootstrap it if ( my $meta = Class::MOP::get_metaclass_by_name($package_name) ) { - return $meta; + return $meta; } else { - my $meta = ( ref $class || $class )->_new({ - 'package' => $package_name, - }); + my $meta = ( ref $class || $class )->_new({ + 'package' => $package_name, + }); - Class::MOP::store_metaclass_by_name($package_name, $meta); + Class::MOP::store_metaclass_by_name($package_name, $meta); - return $meta; + return $meta; } } @@ -276,11 +276,15 @@ sub list_all_package_symbols { sub get_all_package_symbols { my ($self, $type_filter) = @_; + + die "Cannot call get_all_package_symbols as a class method" + unless ref $self; + my $namespace = $self->namespace; return %$namespace unless defined $type_filter; - # for some reason this nasty impl is orders of magnitude aster than a clean version + # for some reason this nasty impl is orders of magnitude faster than a clean version if ( $type_filter eq 'CODE' ) { my $pkg; no strict 'refs';