X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=gitmo%2FMouse.git;a=blobdiff_plain;f=lib%2FMouse%2FMeta%2FMethod%2FConstructor.pm;h=37e2505e1da5e4283f60ca4714535972397b61f8;hp=b899026d842f534871dc095941e673cc2c843423;hb=53d4053e1f62161dd56e6adf8158eb7df72d1af0;hpb=3fee6f680e64b907395238b4d7485e600fee4e46 diff --git a/lib/Mouse/Meta/Method/Constructor.pm b/lib/Mouse/Meta/Method/Constructor.pm index b899026..37e2505 100644 --- a/lib/Mouse/Meta/Method/Constructor.pm +++ b/lib/Mouse/Meta/Method/Constructor.pm @@ -14,7 +14,7 @@ sub generate_constructor_method_inline { my $code = <<"..."; sub { my \$class = shift; - my \$args = $buildargs; + $buildargs; my \$instance = bless {}, \$class; $processattrs; $buildall; @@ -143,20 +143,19 @@ sub _generate_BUILDARGS { my $meta = shift; if ($meta->name->can('BUILDARGS') && $meta->name->can('BUILDARGS') != Mouse::Object->can('BUILDARGS')) { - return '$class->BUILDARGS(@_)'; + return 'my $args = $class->BUILDARGS(@_)'; } return <<'...'; - do { + my $args; if ( scalar @_ == 1 ) { ( ref( $_[0] ) eq 'HASH' ) || Carp::confess "Single parameters to new() must be a HASH ref"; - +{ %{ $_[0] } }; + $args = +{ %{ $_[0] } }; } else { - +{@_}; + $args = +{@_}; } - }; ... }