diff --git a/src/main/java/groovy/lang/MetaClassImpl.java b/src/main/java/groovy/lang/MetaClassImpl.java index 197fa7c79ac..86e10e1f81d 100644 --- a/src/main/java/groovy/lang/MetaClassImpl.java +++ b/src/main/java/groovy/lang/MetaClassImpl.java @@ -3642,7 +3642,6 @@ protected MetaMethod findMixinMethod(String methodName, Class[] arguments) { } protected static MetaMethod findMethodInClassHierarchy(Class instanceKlazz, String methodName, Class[] arguments, MetaClass metaClass) { - if (metaClass instanceof MetaClassImpl) { boolean check = false; for (ClassInfo ci : ((MetaClassImpl) metaClass).theCachedClass.getHierarchy()) { @@ -3653,24 +3652,23 @@ protected static MetaMethod findMethodInClassHierarchy(Class instanceKlazz, Stri } } - if (!check) - return null; + if (!check) return null; } - MetaMethod method = null; - - Class superClass; - if (metaClass.getTheClass().isArray() && !metaClass.getTheClass().getComponentType().isPrimitive() && metaClass.getTheClass().getComponentType() != Object.class) { + final Class superClass; + final Class theClass = metaClass.getTheClass(); + if (theClass.isArray() && !theClass.getComponentType().isPrimitive() && theClass.getComponentType() != Object.class) { superClass = Object[].class; } else { - superClass = metaClass.getTheClass().getSuperclass(); + superClass = theClass.getSuperclass(); } + MetaMethod method = null; if (superClass != null) { MetaClass superMetaClass = GroovySystem.getMetaClassRegistry().getMetaClass(superClass); method = findMethodInClassHierarchy(instanceKlazz, methodName, arguments, superMetaClass); } else { - if (metaClass.getTheClass().isInterface()) { + if (theClass.isInterface()) { MetaClass superMetaClass = GroovySystem.getMetaClassRegistry().getMetaClass(Object.class); method = findMethodInClassHierarchy(instanceKlazz, methodName, arguments, superMetaClass); }