X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FMouse%2FMeta%2FMethod%2FConstructor.pm;h=98a64298c418deeaf568003fe5bf9da6df85eba9;hb=983d58a5ea543a21c48cb04311883f1b36de1874;hp=c45fd9cfeef091875d3918f693075689201c87eb;hpb=a3a09e3898ca09a1dd734439a59d60b18575758c;p=gitmo%2FMouse.git diff --git a/lib/Mouse/Meta/Method/Constructor.pm b/lib/Mouse/Meta/Method/Constructor.pm index c45fd9c..98a6429 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 $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; @@ -24,13 +27,13 @@ sub _generate_constructor { # BUILDARGS %s; my $instance = bless {}, $class; - $metaclass->_initialize_object($instance, $args, 0); + $metaclass->$initializer($instance, $args, 0); # BUILDALL %s; 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.71 +This document describes Mouse version 0.94 =head1 SEE ALSO