X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FMouse%2FMeta%2FMethod%2FConstructor.pm;h=cbfbbb26cd4f47188ab6f0b51b3701dcbdde5cf3;hb=14cf9b5a1724801f786d8c4a79834aa7c063323c;hp=c888390d1705fb80ca911e39a9115cc7eeeef42f;hpb=01d4f728d7f3689267bdfbc997e1fbe02f19fabd;p=gitmo%2FMouse.git diff --git a/lib/Mouse/Meta/Method/Constructor.pm b/lib/Mouse/Meta/Method/Constructor.pm index c888390..cbfbbb2 100644 --- a/lib/Mouse/Meta/Method/Constructor.pm +++ b/lib/Mouse/Meta/Method/Constructor.pm @@ -1,6 +1,8 @@ package Mouse::Meta::Method::Constructor; use Mouse::Util qw(:meta); # enables strict and warnings +use constant _MOUSE_DEBUG => $ENV{MOUSE_DEBUG} ? 1 : 0; + sub _inline_slot{ my(undef, $self_var, $attr_name) = @_; return sprintf '%s->{q{%s}}', $self_var, $attr_name; @@ -13,9 +15,10 @@ sub _generate_constructor { my $buildall = $class->_generate_BUILDALL($metaclass); my $buildargs = $class->_generate_BUILDARGS($metaclass); - my $initializer = $class->_generate_initialize_object($metaclass); - my $source = sprintf(<<'EOT', __LINE__, __FILE__, $metaclass->name, $buildargs, $buildall); -#line %d %s + my $initializer = $metaclass->{_mouse_cache}{_initialize_object} ||= + $class->_generate_initialize_object($metaclass); + my $source = sprintf(<<'EOT', __FILE__, $metaclass->name, $buildargs, $buildall); +#line 1 "%s" package %s; sub { my $class = shift; @@ -30,7 +33,7 @@ sub _generate_constructor { return $instance; } EOT - #warn $source; + warn $source if _MOUSE_DEBUG; my $body; my $e = do{ local $@; @@ -84,10 +87,6 @@ sub _generate_initialize_object { $post_process .= "\$checks[$index]->($instance_slot)\n"; $post_process .= " or $attr_var->_throw_type_constraint_error($instance_slot, $constraint_var);\n"; } - if($is_weak_ref){ - $post_process = "Scalar::Util::weaken($instance_slot) " - . "if ref $instance_slot;\n"; - } # build cde for an attribute if (defined $init_arg) { @@ -148,6 +147,11 @@ sub _generate_initialize_object { $code .= "}\n" if defined $init_arg; + if($is_weak_ref){ + $code .= "Scalar::Util::weaken($instance_slot) " + . "if ref $instance_slot;\n"; + } + push @res, $code; } @@ -165,8 +169,8 @@ sub _generate_initialize_object { push @res, q{$_->[0]->($instance, $_->[1]) for @triggers;}; } - my $source = sprintf <<'EOT', __LINE__, __FILE__, $metaclass->name, join "\n", @res; -#line %d %s + my $source = sprintf <<'EOT', __FILE__, $metaclass->name, join "\n", @res; +#line 1 "%s" package %s; sub { my($meta, $instance, $args, $is_cloning) = @_; @@ -174,7 +178,7 @@ sub _generate_initialize_object { return $instance; } EOT - warn $source if $ENV{MOUSE_DEBUG}; + warn $source if _MOUSE_DEBUG; my $body; my $e = do { local $@; @@ -229,7 +233,7 @@ Mouse::Meta::Method::Constructor - A Mouse method generator for constructors =head1 VERSION -This document describes Mouse version 0.72 +This document describes Mouse version 0.95 =head1 SEE ALSO