my %METAS;
-if(Mouse::Util::_MOUSE_XS){
+if(Mouse::Util::MOUSE_XS){
# register meta storage for performance
Mouse::Util::__register_metaclass_storage(\%METAS, 0);
sub _metaclass_cache { # DEPRECATED
my($class, $name) = @_;
+ Carp::cluck('_metaclass_cache() has been deprecated. Use Mouse::Util::get_metaclass_by_name() instead');
return $METAS{$name};
}
||= $class->_construct_meta(package => $package_name, @args);
}
-sub class_of{
+sub reinitialize {
+ my($class, $package_name, @args) = @_;
+
+ $package_name = $package_name->name if ref $package_name;
+
+ ($package_name && !ref($package_name))
+ || $class->throw_error("You must pass a package name and it cannot be blessed");
+
+ delete $METAS{$package_name};
+ return $class->initialize($package_name, @args);
+}
+
+sub _class_of{
my($class_or_instance) = @_;
return undef unless defined $class_or_instance;
return $METAS{ ref($class_or_instance) || $class_or_instance };
# Means of accessing all the metaclasses that have
# been initialized thus far
-#sub get_all_metaclasses { %METAS }
-sub get_all_metaclass_instances { values %METAS }
-sub get_all_metaclass_names { keys %METAS }
-sub get_metaclass_by_name { $METAS{$_[0]} }
-#sub store_metaclass_by_name { $METAS{$_[0]} = $_[1] }
-#sub weaken_metaclass { weaken($METAS{$_[0]}) }
-#sub does_metaclass_exist { defined $METAS{$_[0]} }
-#sub remove_metaclass_by_name { delete $METAS{$_[0]} }
+#sub _get_all_metaclasses { %METAS }
+sub _get_all_metaclass_instances { values %METAS }
+sub _get_all_metaclass_names { keys %METAS }
+sub _get_metaclass_by_name { $METAS{$_[0]} }
+#sub _store_metaclass_by_name { $METAS{$_[0]} = $_[1] }
+#sub _weaken_metaclass { weaken($METAS{$_[0]}) }
+#sub _does_metaclass_exist { defined $METAS{$_[0]} }
+#sub _remove_metaclass_by_name { delete $METAS{$_[0]} }
sub name;
# add_attribute is an abstract method
sub get_attribute_map { # DEPRECATED
- Carp::cluck('get_attribute_map() has been deprecated');
+ Carp::cluck('get_attribute_map() has been deprecated. Use get_attribute_list() and get_attribute() instead');
return $_[0]->{attributes};
}
sub get_attribute_list{ keys %{$_[0]->{attributes}} }
-
# XXX: for backward compatibility
my %foreign = map{ $_ => undef } qw(
Mouse Mouse::Role Mouse::Util Mouse::Util::TypeConstraints
sub DESTROY{
my($self) = @_;
+ return if $Mouse::Util::in_global_destruction;
+
my $serial_id = $self->{anon_serial_id};
return if !$serial_id;
}
1;
-
__END__
=head1 NAME
=head1 VERSION
-This document describes Mouse version 0.40_05
+This document describes Mouse version 0.46
=head1 SEE ALSO