return $predicate;
}
+sub generate_can_predicate_for {
+ my($methods_ref, $name) = @_;
+
+ my @methods = @{$methods_ref};
+
+ my $predicate = sub{
+ my($instance) = @_;
+ if(Scalar::Util::blessed($instance)){
+ foreach my $method(@methods){
+ if(!$instance->can($method)){
+ return 0;
+ }
+ }
+ return 1;
+ }
+ return 0;
+ };
+
+ if(defined $name){
+ no strict 'refs';
+ *{ caller() . '::' . $name } = $predicate;
+ return;
+ }
+
+ return $predicate;
+}
package
Mouse::Util::TypeConstraints;
die $e if $e; # rethrow
}
+sub BUILDALL {
+ my $self = shift;
+
+ # short circuit
+ return unless $self->can('BUILD');
+
+ for my $class (reverse $self->meta->linearized_isa) {
+ my $build = Mouse::Util::get_code_ref($class, 'BUILD')
+ || next;
+
+ $self->$build(@_);
+ }
+ return;
+}
+
+sub DEMOLISHALL;
+*DEMOLISHALL = \&DESTROY;
+
1;
__END__
=head1 VERSION
-This document describes Mouse version 0.43
+This document describes Mouse version 0.44
=head1 SEE ALSO