X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FMouse%2FMeta%2FMethod%2FConstructor.pm;h=75f589d2eebfeb981871887dd3bb91e86d9dcb49;hb=4e14530461aa16875d80a0574d8f98e4eb5d24a8;hp=37e2505e1da5e4283f60ca4714535972397b61f8;hpb=53d4053e1f62161dd56e6adf8158eb7df72d1af0;p=gitmo%2FMouse.git diff --git a/lib/Mouse/Meta/Method/Constructor.pm b/lib/Mouse/Meta/Method/Constructor.pm index 37e2505..75f589d 100644 --- a/lib/Mouse/Meta/Method/Constructor.pm +++ b/lib/Mouse/Meta/Method/Constructor.pm @@ -5,6 +5,7 @@ use warnings; sub generate_constructor_method_inline { my ($class, $meta) = @_; + my $associated_metaclass_name = $meta->name; my @attrs = $meta->compute_all_applicable_attributes; my $buildall = $class->_generate_BUILDALL($meta); my $buildargs = $class->_generate_BUILDARGS($meta); @@ -14,6 +15,8 @@ sub generate_constructor_method_inline { my $code = <<"..."; sub { my \$class = shift; + return \$class->Mouse::Object::new(\@_) + if \$class ne '$associated_metaclass_name'; $buildargs; my \$instance = bless {}, \$class; $processattrs; @@ -170,7 +173,7 @@ sub _generate_BUILDALL { no warnings 'once'; for my $klass ($meta->linearized_isa) { if (*{ $klass . '::BUILD' }{CODE}) { - push @code, qq{${klass}::BUILD(\$instance, \$args);}; + unshift @code, qq{${klass}::BUILD(\$instance, \$args);}; } } return join "\n", @code;