From a2000f8720fc70d60ead42e92fe29b05e1b3ffd0 Mon Sep 17 00:00:00 2001 From: Chris Hegarty Date: Fri, 22 Dec 2017 15:55:29 +0000 Subject: [PATCH] 8179424: Remove terminally deprecated sun.reflect.Reflection.getCallerClass Reviewed-by: alanb, dfuchs, dholmes, lancea, mchung, rriggs --- make/mapfiles/libjava/mapfile-vers | 1 - make/mapfiles/libjava/reorder-sparc | 1 - make/mapfiles/libjava/reorder-sparcv9 | 1 - make/mapfiles/libjava/reorder-x86 | 1 - src/hotspot/share/include/jvm.h | 13 +-- src/hotspot/share/prims/jvm.cpp | 10 +- .../jdk/internal/reflect/Reflection.java | 8 -- .../share/native/libjava/Reflection.c | 8 +- .../Reflection/GetCallerClassWithDepth.java | 95 ------------------- .../Reflection/GetCallerClassWithDepth.java | 94 ------------------ .../jdkinternals/RemovedJDKInternals.java | 8 +- .../sun/reflect/Reflection.java | 25 ++--- .../tools/jdeps/jdkinternals/src/p/Main.java | 4 + 13 files changed, 22 insertions(+), 247 deletions(-) delete mode 100644 test/jdk/jdk/internal/reflect/Reflection/GetCallerClassWithDepth.java delete mode 100644 test/jdk/sun/reflect/Reflection/GetCallerClassWithDepth.java rename {src/jdk.unsupported/share/classes => test/langtools/tools/jdeps/jdkinternals/patches/jdk.unsupported}/sun/reflect/Reflection.java (54%) diff --git a/make/mapfiles/libjava/mapfile-vers b/make/mapfiles/libjava/mapfile-vers index ce5100c539e..656865f6537 100644 --- a/make/mapfiles/libjava/mapfile-vers +++ b/make/mapfiles/libjava/mapfile-vers @@ -257,7 +257,6 @@ SUNWprivate_1.1 { Java_jdk_internal_reflect_NativeConstructorAccessorImpl_newInstance0; Java_jdk_internal_reflect_NativeMethodAccessorImpl_invoke0; Java_jdk_internal_reflect_Reflection_getCallerClass__; - Java_jdk_internal_reflect_Reflection_getCallerClass__I; Java_jdk_internal_reflect_Reflection_getClassAccessFlags; Java_jdk_internal_misc_VM_latestUserDefinedLoader0; Java_jdk_internal_misc_VM_getuid; diff --git a/make/mapfiles/libjava/reorder-sparc b/make/mapfiles/libjava/reorder-sparc index 990ca32b6fb..43f1afda6b1 100644 --- a/make/mapfiles/libjava/reorder-sparc +++ b/make/mapfiles/libjava/reorder-sparc @@ -27,7 +27,6 @@ text: .text%Java_java_io_FileDescriptor_initIDs; text: .text%Java_java_io_FileOutputStream_initIDs; text: .text%Java_java_lang_System_setIn0; text: .text%Java_sun_reflect_Reflection_getCallerClass__; -text: .text%Java_sun_reflect_Reflection_getCallerClass__I; text: .text%Java_java_lang_Class_forName0; text: .text%Java_java_lang_Object_getClass; text: .text%Java_sun_reflect_Reflection_getClassAccessFlags; diff --git a/make/mapfiles/libjava/reorder-sparcv9 b/make/mapfiles/libjava/reorder-sparcv9 index 4e3ce84b862..3e480bb7682 100644 --- a/make/mapfiles/libjava/reorder-sparcv9 +++ b/make/mapfiles/libjava/reorder-sparcv9 @@ -26,7 +26,6 @@ text: .text%Java_java_io_FileDescriptor_initIDs; text: .text%Java_java_io_FileOutputStream_initIDs; text: .text%Java_java_lang_System_setIn0; text: .text%Java_sun_reflect_Reflection_getCallerClass__; -text: .text%Java_sun_reflect_Reflection_getCallerClass__I; text: .text%Java_java_lang_Class_forName0; text: .text%Java_java_lang_String_intern; text: .text%Java_java_lang_StringUTF16_isBigEndian; diff --git a/make/mapfiles/libjava/reorder-x86 b/make/mapfiles/libjava/reorder-x86 index de28893a4d2..f294a93c4ba 100644 --- a/make/mapfiles/libjava/reorder-x86 +++ b/make/mapfiles/libjava/reorder-x86 @@ -27,7 +27,6 @@ text: .text%Java_java_io_FileDescriptor_initIDs; text: .text%Java_java_io_FileOutputStream_initIDs; text: .text%Java_java_lang_System_setIn0; text: .text%Java_sun_reflect_Reflection_getCallerClass__; -text: .text%Java_sun_reflect_Reflection_getCallerClass__I; text: .text%Java_java_lang_Class_forName0; text: .text%Java_java_lang_String_intern; text: .text%Java_java_lang_StringUTF16_isBigEndian; diff --git a/src/hotspot/share/include/jvm.h b/src/hotspot/share/include/jvm.h index 9865ea3ff6e..c08dcc882f9 100644 --- a/src/hotspot/share/include/jvm.h +++ b/src/hotspot/share/include/jvm.h @@ -317,23 +317,18 @@ JVM_NewArray(JNIEnv *env, jclass eltClass, jint length); JNIEXPORT jobject JNICALL JVM_NewMultiArray(JNIEnv *env, jclass eltClass, jintArray dim); -/* - * java.lang.Class and java.lang.ClassLoader - */ - -#define JVM_CALLER_DEPTH -1 /* * Returns the immediate caller class of the native method invoking * JVM_GetCallerClass. The Method.invoke and other frames due to * reflection machinery are skipped. * - * The depth parameter must be -1 (JVM_DEPTH). The caller is expected - * to be marked with sun.reflect.CallerSensitive. The JVM will throw - * an error if it is not marked propertly. + * The caller is expected to be marked with + * jdk.internal.reflect.CallerSensitive. The JVM will throw an + * error if it is not marked properly. */ JNIEXPORT jclass JNICALL -JVM_GetCallerClass(JNIEnv *env, int depth); +JVM_GetCallerClass(JNIEnv *env); /* diff --git a/src/hotspot/share/prims/jvm.cpp b/src/hotspot/share/prims/jvm.cpp index ad3a1cedb46..e84feae5d1b 100644 --- a/src/hotspot/share/prims/jvm.cpp +++ b/src/hotspot/share/prims/jvm.cpp @@ -678,17 +678,9 @@ JVM_END // Misc. class handling /////////////////////////////////////////////////////////// -JVM_ENTRY(jclass, JVM_GetCallerClass(JNIEnv* env, int depth)) +JVM_ENTRY(jclass, JVM_GetCallerClass(JNIEnv* env)) JVMWrapper("JVM_GetCallerClass"); - // Pre-JDK 8 and early builds of JDK 8 don't have a CallerSensitive annotation; or - // sun.reflect.Reflection.getCallerClass with a depth parameter is provided - // temporarily for existing code to use until a replacement API is defined. - if (SystemDictionary::reflect_CallerSensitive_klass() == NULL || depth != JVM_CALLER_DEPTH) { - Klass* k = thread->security_get_caller_class(depth); - return (k == NULL) ? NULL : (jclass) JNIHandles::make_local(env, k->java_mirror()); - } - // Getting the class of the caller frame. // // The call stack at this point looks something like this: diff --git a/src/java.base/share/classes/jdk/internal/reflect/Reflection.java b/src/java.base/share/classes/jdk/internal/reflect/Reflection.java index 384b67734a3..c05273c3a07 100644 --- a/src/java.base/share/classes/jdk/internal/reflect/Reflection.java +++ b/src/java.base/share/classes/jdk/internal/reflect/Reflection.java @@ -64,14 +64,6 @@ public class Reflection { @HotSpotIntrinsicCandidate public static native Class getCallerClass(); - /** - * @deprecated This method will be removed. - * This method is a private JDK API and retained temporarily to - * simplify the implementation of sun.misc.Reflection.getCallerClass. - */ - @Deprecated(forRemoval=true) - public static native Class getCallerClass(int depth); - /** Retrieves the access flags written to the class file. For inner classes these flags may differ from those returned by Class.getModifiers(), which searches the InnerClasses diff --git a/src/java.base/share/native/libjava/Reflection.c b/src/java.base/share/native/libjava/Reflection.c index 0a5327eb1fa..b634726c500 100644 --- a/src/java.base/share/native/libjava/Reflection.c +++ b/src/java.base/share/native/libjava/Reflection.c @@ -30,13 +30,7 @@ JNIEXPORT jclass JNICALL Java_jdk_internal_reflect_Reflection_getCallerClass__(JNIEnv *env, jclass unused) { - return JVM_GetCallerClass(env, JVM_CALLER_DEPTH); -} - -JNIEXPORT jclass JNICALL -Java_jdk_internal_reflect_Reflection_getCallerClass__I(JNIEnv *env, jclass unused, jint depth) -{ - return JVM_GetCallerClass(env, depth); + return JVM_GetCallerClass(env); } JNIEXPORT jint JNICALL diff --git a/test/jdk/jdk/internal/reflect/Reflection/GetCallerClassWithDepth.java b/test/jdk/jdk/internal/reflect/Reflection/GetCallerClassWithDepth.java deleted file mode 100644 index c220db3f432..00000000000 --- a/test/jdk/jdk/internal/reflect/Reflection/GetCallerClassWithDepth.java +++ /dev/null @@ -1,95 +0,0 @@ -/* - * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* - * @test - * @bug 8025799 - * @summary Reflection.getCallerClass(int) - * @modules java.base/jdk.internal.reflect - * @run main GetCallerClassWithDepth - */ - -import jdk.internal.reflect.Reflection; - -public class GetCallerClassWithDepth { - public static void main(String[] args) throws Exception { - Class c = Test.test(); - assertEquals(c, GetCallerClassWithDepth.class); - Class caller = Test.caller(); - assertEquals(caller, GetCallerClassWithDepth.class); - Test.selfTest(); - - try { - Reflection.getCallerClass(-1); - throw new RuntimeException("getCallerClass(-1) should fail"); - } catch (Error e) { - System.out.println("Expected: " + e.getMessage()); - } - } - - public Class getCallerClass() { - // 0: Reflection 1: getCallerClass 2: Test.test 3: main - return Reflection.getCallerClass(3); - } - - static void assertEquals(Class c, Class expected) { - if (c != expected) { - throw new RuntimeException("Incorrect caller: " + c); - } - } - - static class Test { - // Returns the caller of this method - public static Class test() { - return new GetCallerClassWithDepth().getCallerClass(); - } - - // Returns the caller of this method - public static Class caller() { - // 0: Reflection 1: Test.caller 2: main - return Reflection.getCallerClass(2); - } - public static void selfTest() { - // 0: Reflection 1: Test.selfTest - Class c = Reflection.getCallerClass(1); - assertEquals(c, Test.class); - Inner1.deep(); - } - - static class Inner1 { - static void deep() { - deeper(); - } - static void deeper() { - Inner2.deepest(); - } - static class Inner2 { - static void deepest() { - // 0: Reflection 1: deepest 2: deeper 3: deep 4: Test.selfTest - Class c = Reflection.getCallerClass(4); - assertEquals(c, Test.class); - } - } - } - } -} diff --git a/test/jdk/sun/reflect/Reflection/GetCallerClassWithDepth.java b/test/jdk/sun/reflect/Reflection/GetCallerClassWithDepth.java deleted file mode 100644 index 1b2650d8543..00000000000 --- a/test/jdk/sun/reflect/Reflection/GetCallerClassWithDepth.java +++ /dev/null @@ -1,94 +0,0 @@ -/* - * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* - * @test - * @bug 8137058 - * @summary Basic test for the unsupported Reflection.getCallerClass(int) - * @modules jdk.unsupported - */ - -import sun.reflect.Reflection; - -public class GetCallerClassWithDepth { - public static void main(String[] args) throws Exception { - Class c = Test.test(); - assertEquals(c, GetCallerClassWithDepth.class); - Class caller = Test.caller(); - assertEquals(caller, GetCallerClassWithDepth.class); - Test.selfTest(); - - try { - Reflection.getCallerClass(-1); - throw new RuntimeException("getCallerClass(-1) should fail"); - } catch (Error e) { - System.out.println("Expected: " + e.getMessage()); - } - } - - public Class getCallerClass() { - // 0: Reflection 1: getCallerClass 2: Test.test 3: main - return Reflection.getCallerClass(3); - } - - static void assertEquals(Class c, Class expected) { - if (c != expected) { - throw new RuntimeException("Incorrect caller: " + c); - } - } - - static class Test { - // Returns the caller of this method - public static Class test() { - return new GetCallerClassWithDepth().getCallerClass(); - } - - // Returns the caller of this method - public static Class caller() { - // 0: Reflection 1: Test.caller 2: main - return Reflection.getCallerClass(2); - } - public static void selfTest() { - // 0: Reflection 1: Test.selfTest - Class c = Reflection.getCallerClass(1); - assertEquals(c, Test.class); - Inner1.deep(); - } - - static class Inner1 { - static void deep() { - deeper(); - } - static void deeper() { - Inner2.deepest(); - } - static class Inner2 { - static void deepest() { - // 0: Reflection 1: deepest 2: deeper 3: deep 4: Test.selfTest - Class c = Reflection.getCallerClass(4); - assertEquals(c, Test.class); - } - } - } - } -} diff --git a/test/langtools/tools/jdeps/jdkinternals/RemovedJDKInternals.java b/test/langtools/tools/jdeps/jdkinternals/RemovedJDKInternals.java index b97c27dcd46..6516e8f6d64 100644 --- a/test/langtools/tools/jdeps/jdkinternals/RemovedJDKInternals.java +++ b/test/langtools/tools/jdeps/jdkinternals/RemovedJDKInternals.java @@ -85,7 +85,8 @@ public class RemovedJDKInternals { .reference("p.Main", "java.lang.Object", "java.base") .reference("p.Main", "java.util.Iterator", "java.base") .reference("p.S", "java.lang.Object", "java.base") - .jdkInternal("p.Main", "sun.reflect.Reflection", "jdk.unsupported") + .jdkInternal("p.Main", "sun.reflect.ReflectionFactory", "jdk.unsupported") + .removedJdkInternal("p.Main", "sun.reflect.Reflection") .removedJdkInternal("p.Main", "com.sun.image.codec.jpeg.JPEGCodec") .removedJdkInternal("p.Main", "sun.misc.Service") .removedJdkInternal("p.Main", "sun.misc.SoftCache") @@ -118,7 +119,8 @@ public class RemovedJDKInternals { "com.sun.image.codec.jpeg.JPEGCodec", "Use javax.imageio @since 1.4", "sun.misc.Service", "Use java.util.ServiceLoader @since 1.6", "sun.misc.SoftCache", "Removed. See http://openjdk.java.net/jeps/260", - "sun.reflect.Reflection", "Use java.lang.StackWalker @since 9" + "sun.reflect.Reflection", "Use java.lang.StackWalker @since 9", + "sun.reflect.ReflectionFactory", "See http://openjdk.java.net/jeps/260" ); @Test @@ -139,6 +141,8 @@ public class RemovedJDKInternals { int pos = line.indexOf("Use "); if (pos < 0) pos = line.indexOf("Removed. "); + if (pos < 0) + pos = line.indexOf("See "); assertTrue(pos > 0); String name = line.substring(0, pos).trim(); diff --git a/src/jdk.unsupported/share/classes/sun/reflect/Reflection.java b/test/langtools/tools/jdeps/jdkinternals/patches/jdk.unsupported/sun/reflect/Reflection.java similarity index 54% rename from src/jdk.unsupported/share/classes/sun/reflect/Reflection.java rename to test/langtools/tools/jdeps/jdkinternals/patches/jdk.unsupported/sun/reflect/Reflection.java index ff6c0c6e3ee..344837822e2 100644 --- a/src/jdk.unsupported/share/classes/sun/reflect/Reflection.java +++ b/test/langtools/tools/jdeps/jdkinternals/patches/jdk.unsupported/sun/reflect/Reflection.java @@ -1,12 +1,10 @@ /* - * Copyright (c) 2001, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. + * published by the Free Software Foundation. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or @@ -25,22 +23,11 @@ package sun.reflect; +/* + * JDK removed internal API + */ public class Reflection { - - private Reflection() { } - - /** - * @deprecated This method is an internal API and will be removed. - * Use {@link StackWalker} to walk the stack and obtain the caller class - * with {@link StackWalker.StackFrame#getDeclaringClass} instead. - */ - @Deprecated(forRemoval=true) - @SuppressWarnings("removal") // Reflection.getCallerClass public static Class getCallerClass(int depth) { - if (depth < 0) - throw new InternalError("depth must be positive"); - - // increase depth to account for delegation to the internal impl - return jdk.internal.reflect.Reflection.getCallerClass(depth + 1); + return null; } } diff --git a/test/langtools/tools/jdeps/jdkinternals/src/p/Main.java b/test/langtools/tools/jdeps/jdkinternals/src/p/Main.java index aaa30af8b39..0d5be00af8c 100644 --- a/test/langtools/tools/jdeps/jdkinternals/src/p/Main.java +++ b/test/langtools/tools/jdeps/jdkinternals/src/p/Main.java @@ -27,10 +27,14 @@ import com.sun.image.codec.jpeg.JPEGCodec; import sun.misc.Service; import sun.misc.SoftCache; import sun.reflect.Reflection; +import sun.reflect.ReflectionFactory; public class Main { public static void main() { // in jdk.unsupported + ReflectionFactory factory = ReflectionFactory.getReflectionFactory(); + + // removed from jdk.unsupported in JDK 11 Class caller = Reflection.getCallerClass(2); // removed