$class->throw_error("Unknown accessor type '$type'");
}
- # XXX: an anon class can be a runtime created class
- if ($attribute->is_lazy || $class->is_anon_class) {
+ if ($attribute->is_lazy) {
my $value;
if (defined $builder){
}
elsif(defined $constraint){
$accessor .= "my \$tmp = $value;\n";
+ #XXX: The following 'defined and' check is for backward compatibility
+ $accessor .= "defined(\$tmp) and ";
+
$accessor .= "\$compiled_type_constraint->(\$tmp)";
- $accessor .= "or \$attribute->verify_type_constraint_error(\$name, \$tmp, \$constraint);\n";
+ $accessor .= " || \$attribute->verify_type_constraint_error(\$name, \$tmp, \$constraint);\n";
$accessor .= "$slot = \$tmp;\n";
}
else{
1;
+__END__
+
+=head1 NAME
+
+Mouse::Meta::Method::Accessor - A Mouse method generator for accessors
+
+=head1 VERSION
+
+This document describes Mouse version 0.39
+
+=head1 SEE ALSO
+
+L<Moose::Meta::Method::Accessor>
+
+=cut