use Mouse::Util; # enables strict and warnings
use Scalar::Util qw(blessed);
+sub _inline_slot{
+ my(undef, $self_var, $attr_name) = @_;
+ return sprintf '%s->{q{%s}}', $self_var, $attr_name;
+}
+
sub _generate_accessor{
- my (undef, $attribute, $class, $type) = @_;
+ my ($method_class, $attribute, $class, $type) = @_;
my $name = $attribute->name;
my $default = $attribute->default;
my $compiled_type_constraint = defined($constraint) ? $constraint->_compiled_type_constraint : undef;
my $self = '$_[0]';
- my $key = "q{$name}";
- my $slot = "$self\->{$key}";
+ my $slot = $method_class->_inline_slot($self, $name);;
$type ||= 'accessor';
$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){
$value = '$default';
}
+ $accessor .= "if(!exists $slot){\n";
if($should_coerce){
- $value = "\$constraint->coerce($value)";
+ $accessor .= "$slot = \$constraint->coerce($value)";
}
-
- $accessor .= "$slot = $value if !exists $slot;\n";
+ 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 .= " || \$attribute->verify_type_constraint_error(\$name, \$tmp, \$constraint);\n";
+ $accessor .= "$slot = \$tmp;\n";
+ }
+ else{
+ $accessor .= "$slot = $value;\n";
+ }
+ $accessor .= "}\n";
}
if ($should_deref) {
1;
+__END__
+
+=head1 NAME
+
+Mouse::Meta::Method::Accessor - A Mouse method generator for accessors
+
+=head1 VERSION
+
+This document describes Mouse version 0.40_01
+
+=head1 SEE ALSO
+
+L<Moose::Meta::Method::Accessor>
+
+=cut