X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FMoose%2FMeta%2FMethod%2FConstructor.pm;h=5a83ddcf61de2c5a3a6876a80e754c5ea32c7696;hb=86850486e3e2425c803df63cb6f10ee89a8d4a76;hp=68de04a270605ec42318cc0ef8d3ddc741a7b1cc;hpb=2b54d2a6b7bf40c4408ffbc117f6b6d77ee35c67;p=gitmo%2FMoose.git diff --git a/lib/Moose/Meta/Method/Constructor.pm b/lib/Moose/Meta/Method/Constructor.pm index 68de04a..5a83ddc 100644 --- a/lib/Moose/Meta/Method/Constructor.pm +++ b/lib/Moose/Meta/Method/Constructor.pm @@ -6,7 +6,7 @@ use warnings; use Scalar::Util 'blessed', 'weaken', 'looks_like_number', 'refaddr'; -our $VERSION = '1.08'; +our $VERSION = '1.12'; our $AUTHORITY = 'cpan:STEVAN'; use base 'Moose::Meta::Method', @@ -95,11 +95,14 @@ sub _initialize_body { defined $_ ? $_->_compiled_type_constraint : undef; } @type_constraints; + my $defaults = [map { $_->default } @$attrs]; + my ( $code, $e ) = $self->_compile_code( code => $source, environment => { '$meta' => \$self, '$attrs' => \$attrs, + '$defaults' => \$defaults, '@type_constraints' => \@type_constraints, '@type_constraint_bodies' => \@type_constraint_bodies, }, @@ -242,7 +245,7 @@ sub _generate_slot_initializer { push @source => ('my $val = $params->{\'' . $init_arg . '\'};'); if ($is_moose && $attr->has_type_constraint) { - if ($attr->should_coerce) { + if ($attr->should_coerce && $attr->type_constraint->has_coercion) { push @source => $self->_generate_type_coercion( $attr, '$type_constraints[' . $index . ']', @@ -307,7 +310,7 @@ sub _generate_type_constraint_and_coercion { return unless $attr->has_type_constraint; my @source; - if ($attr->should_coerce) { + if ($attr->should_coerce && $attr->type_constraint->has_coercion) { push @source => $self->_generate_type_coercion( $attr, '$type_constraints[' . $index . ']', @@ -340,22 +343,6 @@ sub _generate_type_constraint_check { ); } -sub _generate_default_value { - my ($self, $attr, $index) = @_; - # NOTE: - # default values can either be CODE refs - # in which case we need to call them. Or - # they can be scalars (strings/numbers) - # in which case we can just deal with them - # in the code we eval. - if ($attr->is_default_a_coderef) { - return '$attrs->[' . $index . ']->default($instance)'; - } - else { - return q{"} . quotemeta( $attr->default ) . q{"}; - } -} - 1; __END__