X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FMooseX%2FUndefTolerant%2FConstructor.pm;h=9f4046c6c6867a5a37cb63b481f99bdc056e9cf3;hb=e5d1b64215dcded06a34e7c389958c79f33c3906;hp=47d81283c857615c8a5846794279d4b4bc094e85;hpb=d10a4d7f63850b562f9c5267707b9072b84d33f3;p=gitmo%2FMooseX-UndefTolerant.git diff --git a/lib/MooseX/UndefTolerant/Constructor.pm b/lib/MooseX/UndefTolerant/Constructor.pm index 47d8128..9f4046c 100644 --- a/lib/MooseX/UndefTolerant/Constructor.pm +++ b/lib/MooseX/UndefTolerant/Constructor.pm @@ -1,26 +1,33 @@ package MooseX::UndefTolerant::Constructor; use Moose::Role; -around('_generate_slot_initializer', sub { - my $orig = shift; - my $self = shift; - my $attr = $self->_attributes->[$_[0]]->init_arg; +around _generate_slot_initializer => sub { + my $orig = shift; + my $self = shift; - # insert a line of code at the start of the initializer, - # clearing the param if it's undefined. + # note the key in the params may not match the attr name. + my $key_name = $self->_attributes->[$_[0]]->init_arg; - if (defined $attr) { - my $tolerant_code = - qq# delete \$params->{'$attr'} unless # . - qq# exists \$params->{'$attr'} && defined \$params->{'$attr'};\n#; + # insert a line of code at the start of the initializer, + # clearing the param if it's undefined. - return $tolerant_code . $self->$orig(@_); - } - else { - return $self->$orig(@_); + if (defined $key_name) + { + # leave the value unscathed if the attribute's type constraint can + # handle undef (or doesn't have one, which implicitly means it can) + my $type_constraint = $self->_attributes->[$_[0]]->type_constraint; + if ($type_constraint and not $type_constraint->check(undef)) + { + my $tolerant_code = + qq# delete \$params->{'$key_name'} unless # . + qq# exists \$params->{'$key_name'} && defined \$params->{'$key_name'};\n#; + + return $tolerant_code . $self->$orig(@_); } -}); + } -no Moose::Role; + return $self->$orig(@_); +}; +no Moose::Role; 1;