X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FMouse%2FMeta%2FClass.pm;h=6abc7b2740fb2d33e821624a3400ef31d297c1f0;hb=8215d7254eb706c929b0cfa9efafb7a5e6db658b;hp=c7c44339bb8c9dcced97c4d2d826126b5f846362;hpb=31c5194bc6a176cec4de515163d27f174eba5c9b;p=gitmo%2FMouse.git diff --git a/lib/Mouse/Meta/Class.pm b/lib/Mouse/Meta/Class.pm index c7c4433..6abc7b2 100644 --- a/lib/Mouse/Meta/Class.pm +++ b/lib/Mouse/Meta/Class.pm @@ -171,18 +171,13 @@ sub _initialize_instance{ my $key = $attribute->name; if (defined($from) && exists($args->{$from})) { - $args->{$from} = $attribute->coerce_constraint($args->{$from}) - if $attribute->should_coerce; - - $attribute->verify_against_type_constraint($args->{$from}); - - $instance->{$key} = $args->{$from}; + $instance->{$key} = $attribute->_coerce_and_verify($args->{$from}); weaken($instance->{$key}) if ref($instance->{$key}) && $attribute->is_weak_ref; if ($attribute->has_trigger) { - push @triggers_queue, [ $attribute->trigger, $args->{$from} ]; + push @triggers_queue, [ $attribute->trigger, $instance->{$from} ]; } } else { @@ -190,17 +185,12 @@ sub _initialize_instance{ unless ($attribute->is_lazy) { my $default = $attribute->default; my $builder = $attribute->builder; - my $value = $attribute->has_builder - ? $instance->$builder - : ref($default) eq 'CODE' - ? $default->($instance) - : $default; - - $value = $attribute->coerce_constraint($value) - if $attribute->should_coerce; - $attribute->verify_against_type_constraint($value); + my $value = $builder ? $instance->$builder() + : ref($default) eq 'CODE' ? $instance->$default() + : $default; - $instance->{$key} = $value; + # XXX: we cannot use $attribute->set_value() because it invokes triggers. + $instance->{$key} = $attribute->_coerce_and_verify($value, $instance);; weaken($instance->{$key}) if ref($instance->{$key}) && $attribute->is_weak_ref;