Don't bother checking the expected constructor class for an inlined
Dave Rolsky [Thu, 4 Dec 2008 23:11:49 +0000 (23:11 +0000)]
constructor.

Note that while this is correct, it's also largely pointless. See the
new comment for an explanation of why this is so.

lib/Moose/Meta/Method/Constructor.pm

index 57a1b7a..2357fe8 100644 (file)
@@ -51,6 +51,8 @@ sub can_be_inlined {
     my $self      = shift;
     my $metaclass = $self->associated_metaclass;
 
+    my $expected_class = $self->_expected_constructor_class;
+
     # If any of our parents have been made immutable, we are okay to
     # inline our own new method. The assumption is that an inlined new
     # method provided by a parent does not actually get used by
@@ -58,16 +60,23 @@ sub can_be_inlined {
     for my $meta (
         grep { $_->is_immutable }
         map  { ( ref $metaclass )->initialize($_) }
+        grep { $_ ne $expected_class }
         $metaclass->linearized_isa
         ) {
         my $transformer = $meta->get_immutable_transformer;
 
+        # This is actually a false positive if we're in a subclass of
+        # this class, _and_ the expected class is not overridden (but
+        # should be), and the real expected class is actually
+        # immutable itself (see Fey::Object::Table for an example of
+        # how this can happen). I'm not sure how to actually handle
+        # that case, since it's effectively a bug in the subclass (for
+        # not overriding _expected_constructor_class).
         return 1 if $transformer->inlined_constructor;
     }
 
     if ( my $constructor = $metaclass->find_method_by_name( $self->name ) ) {
         my $class = $self->associated_metaclass->name;
-        my $expected_class = $self->_expected_constructor_class;
 
         if ( $constructor->body != $expected_class->can('new') ) {
             warn "Not inlining a constructor for $class since it is not"