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);
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};
}
# 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
return grep { $self->has_method($_) } keys %{ $self->namespace };
}
+sub _collect_methods { # Mouse specific
+ my($meta, @args) = @_;
+
+ my @methods;
+ foreach my $arg(@args){
+ if(my $type = ref $arg){
+ if($type eq 'Regexp'){
+ push @methods, grep { $_ =~ $arg } $meta->get_all_method_names;
+ }
+ elsif($type eq 'ARRAY'){
+ push @methods, @{$arg};
+ }
+ else{
+ my $subname = ( caller(1) )[3];
+ $meta->throw_error(
+ sprintf(
+ 'Methods passed to %s must be provided as a list, ArrayRef or regular expression, not %s',
+ $subname,
+ $type,
+ )
+ );
+ }
+ }
+ else{
+ push @methods, $arg;
+ }
+ }
+ return @methods;
+}
+
+
{
my $ANON_SERIAL = 0;
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_07
+This document describes Mouse version 0.50_02
=head1 SEE ALSO