rename a variable, to make it more clear that we are not working with the Moose:...
Karen Etheridge [Wed, 3 Nov 2010 23:01:12 +0000 (16:01 -0700)]
lib/MooseX/UndefTolerant/Constructor.pm

index 47d8128..841811d 100644 (file)
@@ -4,15 +4,17 @@ use Moose::Role;
 around('_generate_slot_initializer', sub {
         my $orig = shift;
         my $self = shift;
-        my $attr = $self->_attributes->[$_[0]]->init_arg;
+
+        # note the key in the params may not match the attr name.
+        my $key_name = $self->_attributes->[$_[0]]->init_arg;
 
         # insert a line of code at the start of the initializer,
         # clearing the param if it's undefined.
 
-        if (defined $attr) {
+        if (defined $key_name) {
                 my $tolerant_code = 
-                     qq# delete \$params->{'$attr'} unless # . 
-                     qq# exists \$params->{'$attr'} && defined \$params->{'$attr'};\n#;
+                     qq# delete \$params->{'$key_name'} unless # . 
+                     qq# exists \$params->{'$key_name'} && defined \$params->{'$key_name'};\n#;
 
                 return $tolerant_code . $self->$orig(@_);
         }