From 74fa722567cccf62c417e8f189ab75b8de03d85e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Hannes=20Walln=C3=B6fer?= Date: Wed, 5 Dec 2018 19:17:22 +0100 Subject: [PATCH] 8214795: Add safety check to dynalink inner class lookup Reviewed-by: sundar, attila --- .../classes/jdk/dynalink/beans/AccessibleMembersLookup.java | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/jdk.dynalink/share/classes/jdk/dynalink/beans/AccessibleMembersLookup.java b/src/jdk.dynalink/share/classes/jdk/dynalink/beans/AccessibleMembersLookup.java index 22e15013c32..fbdeccb6424 100644 --- a/src/jdk.dynalink/share/classes/jdk/dynalink/beans/AccessibleMembersLookup.java +++ b/src/jdk.dynalink/share/classes/jdk/dynalink/beans/AccessibleMembersLookup.java @@ -216,7 +216,10 @@ class AccessibleMembersLookup { // were not yet loaded, they'll only get loaded in a non-resolved state; no static initializers for // them will trigger just by doing this. // Don't overwrite an inner class with an inherited inner class with the same name. - innerClasses.putIfAbsent(innerClass.getSimpleName(), innerClass); + Class previousClass = innerClasses.get(innerClass.getSimpleName()); + if (previousClass == null || previousClass.getDeclaringClass().isAssignableFrom(innerClass.getDeclaringClass())) { + innerClasses.put(innerClass.getSimpleName(), innerClass); + } } } else { searchSuperTypes = true;