X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=gitmo%2FMouse.git;a=blobdiff_plain;f=lib%2FMouse%2FMeta%2FModule.pm;h=1c5175a912f43c8a3abb06489a6e301d83abb854;hp=793de9b2094c4d9d4b7af0a2bd4c65ba0d9b543a;hb=81fd550d4417451af22a45f26b93829b4515bb89;hpb=8aba926dbf11e9cf418c7c79b925d15e60e1e990 diff --git a/lib/Mouse/Meta/Module.pm b/lib/Mouse/Meta/Module.pm index 793de9b..1c5175a 100755 --- a/lib/Mouse/Meta/Module.pm +++ b/lib/Mouse/Meta/Module.pm @@ -7,7 +7,7 @@ use Scalar::Util (); my %METAS; # XXX: work around a warning "useless use of a constant in void context" in 5.6.2 -if(&Mouse::Util::_MOUSE_XS()){ +if(&Mouse::Util::MOUSE_XS){ # register meta storage for performance Mouse::Util::__register_metaclass_storage(\%METAS, 0); @@ -89,7 +89,6 @@ sub remove_attribute { delete $_[0]->{attributes}->{$_[1]} } sub get_attribute_list{ keys %{$_[0]->{attributes}} } - # XXX: for backward compatibility my %foreign = map{ $_ => undef } qw( Mouse Mouse::Role Mouse::Util Mouse::Util::TypeConstraints @@ -265,6 +264,8 @@ sub get_method_list { sub DESTROY{ my($self) = @_; + return if $Mouse::Util::in_global_destruction; + my $serial_id = $self->{anon_serial_id}; return if !$serial_id; @@ -302,7 +303,6 @@ sub throw_error{ } 1; - __END__ =head1 NAME @@ -311,7 +311,7 @@ Mouse::Meta::Module - The base class for Mouse::Meta::Class and Mouse::Meta::Rol =head1 VERSION -This document describes Mouse version 0.40_07 +This document describes Mouse version 0.45 =head1 SEE ALSO