package
Mouse::Util::TypeConstraints;
+use Scalar::Util qw(blessed looks_like_number openhandle);
+
+sub _generate_class_type_for{
+ my($for_class, $name) = @_;
+
+ my $predicate = sub{ blessed($_[0]) && $_[0]->isa($for_class) };
+
+ if(defined $name){
+ no strict 'refs';
+ *{ caller() . '::' . $name } = $predicate;
+ return;
+ }
+
+ return $predicate;
+}
+
+
sub Any { 1 }
sub Item { 1 }
-sub Maybe { 1 }
sub Bool { $_[0] ? $_[0] eq '1' : 1 }
sub Undef { !defined($_[0]) }
return \%{ $name . '::' };
}
+sub add_method {
+ my($self, $name, $code) = @_;
+
+ if(!defined $name){
+ $self->throw_error('You must pass a defined name');
+ }
+ if(!defined $code){
+ $self->throw_error('You must pass a defined code');
+ }
+
+ if(ref($code) ne 'CODE'){
+ $code = \&{$code}; # coerce
+ }
+
+ $self->{methods}->{$name} = $code; # Moose stores meta object here.
+
+ my $pkg = $self->name;
+ no strict 'refs';
+ no warnings 'redefine', 'once';
+ *{ $pkg . '::' . $name } = $code;
+ return;
+}
+
+
package
Mouse::Meta::Class;
package
Mouse::Meta::Attribute;
+use Mouse::Meta::Method::Accessor;
# readers
sub has_documentation { exists $_[0]->{documentation} }
+sub accessor_metaclass(){ 'Mouse::Meta::Method::Accessor' }
+
package
Mouse::Meta::TypeConstraint;
sub _compiled_type_constraint{ $_[0]->{compiled_type_constraint} }
-sub has_coercion{ exists $_[0]->{_compiled_type_coercion} }
+sub _compiled_type_coercion { $_[0]->{_compiled_type_coercion} }
-package
- Mouse::Meta::Method::Accessor;
+
+sub has_coercion{ exists $_[0]->{_compiled_type_coercion} }
1;
__END__