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){
}
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.40_01
+
+=head1 SEE ALSO
+
+L<Moose::Meta::Method::Accessor>
+
+=cut