diff --git a/src/java.management/share/classes/javax/management/loading/MLet.java b/src/java.management/share/classes/javax/management/loading/MLet.java index 250e5945645..aacf73e4821 100644 --- a/src/java.management/share/classes/javax/management/loading/MLet.java +++ b/src/java.management/share/classes/javax/management/loading/MLet.java @@ -162,8 +162,14 @@ import javax.management.ServiceNotFoundException; *

Note - The MLet class loader uses the {@link javax.management.MBeanServerFactory#getClassLoaderRepository(javax.management.MBeanServer)} * to load classes that could not be found in the loaded jar files. * + * @deprecated This API is part of Management Applets (m-lets), which is a legacy feature that allows loading + * of remote MBeans. This feature is not usable without a Security Manager, which is deprecated and subject to + * removal in a future release. Consequently, this API is also deprecated and subject to removal. There is no replacement. + * * @since 1.5 */ +@Deprecated(since="20", forRemoval=true) +@SuppressWarnings("removal") public class MLet extends java.net.URLClassLoader implements MLetMBean, MBeanRegistration, Externalizable { diff --git a/src/java.management/share/classes/javax/management/loading/MLetContent.java b/src/java.management/share/classes/javax/management/loading/MLetContent.java index 32b099a3615..638f7b38c21 100644 --- a/src/java.management/share/classes/javax/management/loading/MLetContent.java +++ b/src/java.management/share/classes/javax/management/loading/MLetContent.java @@ -39,11 +39,15 @@ import java.util.Map; * It can be consulted by a subclass of {@link MLet} that overrides * the {@link MLet#check MLet.check} method. * + * @deprecated This API is part of Management Applets (m-lets), which is a legacy feature that allows loading + * of remote MBeans. This feature is not usable without a Security Manager, which is deprecated and subject to + * removal in a future release. Consequently, this API is also deprecated and subject to removal. There is no replacement. + * * @since 1.6 */ +@Deprecated(since="20", forRemoval=true) public class MLetContent { - /** * A map of the attributes of the MLET tag * and their values. diff --git a/src/java.management/share/classes/javax/management/loading/MLetMBean.java b/src/java.management/share/classes/javax/management/loading/MLetMBean.java index a18b08d70fe..1e57cef9be7 100644 --- a/src/java.management/share/classes/javax/management/loading/MLetMBean.java +++ b/src/java.management/share/classes/javax/management/loading/MLetMBean.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2006, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2022, 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 @@ -39,11 +39,15 @@ import javax.management.*; * Exposes the remote management interface of the MLet * MBean. * + * @deprecated This API is part of Management Applets (m-lets), which is a legacy feature that allows loading + * of remote MBeans. This feature is not usable without a Security Manager, which is deprecated and subject to + * removal in a future release. Consequently, this API is also deprecated and subject to removal. There is no replacement. + * * @since 1.5 */ +@Deprecated(since="20", forRemoval=true) public interface MLetMBean { - /** * Loads a text file containing MLET tags that define the MBeans * to be added to the MBean server. The location of the text file is diff --git a/src/java.management/share/classes/javax/management/loading/MLetObjectInputStream.java b/src/java.management/share/classes/javax/management/loading/MLetObjectInputStream.java index e0938316a1b..159fa85b22e 100644 --- a/src/java.management/share/classes/javax/management/loading/MLetObjectInputStream.java +++ b/src/java.management/share/classes/javax/management/loading/MLetObjectInputStream.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2008, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2022, 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 @@ -38,13 +38,16 @@ import java.lang.reflect.Array; * * @since 1.5 */ +@Deprecated(since="20", forRemoval=true) class MLetObjectInputStream extends ObjectInputStream { + @SuppressWarnings("removal") private MLet loader; /** * Loader must be non-null; */ + @SuppressWarnings("removal") public MLetObjectInputStream(InputStream in, MLet loader) throws IOException, StreamCorruptedException { diff --git a/src/java.management/share/classes/javax/management/loading/MLetParser.java b/src/java.management/share/classes/javax/management/loading/MLetParser.java index 0e53b1ddcc6..41bb9d35878 100644 --- a/src/java.management/share/classes/javax/management/loading/MLetParser.java +++ b/src/java.management/share/classes/javax/management/loading/MLetParser.java @@ -47,6 +47,7 @@ import java.lang.System.Logger.Level; * * @since 1.5 */ +@Deprecated(since="20", forRemoval=true) class MLetParser { /* @@ -153,6 +154,7 @@ class MLetParser { /** * Scan an html file for {@literal } tags. */ + @SuppressWarnings("removal") public List parse(URL url) throws IOException { // Warning Messages String requiresTypeWarning = " tag requires type parameter."; @@ -249,7 +251,7 @@ class MLetParser { /** * Parse the document pointed by the URL urlname */ - @SuppressWarnings("deprecation") + @SuppressWarnings("removal") public List parseURL(String urlname) throws IOException { // Parse the document // diff --git a/src/java.management/share/classes/javax/management/loading/PrivateMLet.java b/src/java.management/share/classes/javax/management/loading/PrivateMLet.java index f9b0d0ebd77..372db255b72 100644 --- a/src/java.management/share/classes/javax/management/loading/PrivateMLet.java +++ b/src/java.management/share/classes/javax/management/loading/PrivateMLet.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2002, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2002, 2022, 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 @@ -36,9 +36,14 @@ import java.net.URLStreamHandlerFactory; * ClassLoaderRepository}. This is true because this class implements * the interface {@link PrivateClassLoader}. * + * @deprecated This API is part of Management Applets (m-lets), which is a legacy feature that allows loading + * of remote MBeans. This feature is not usable without a Security Manager, which is deprecated and subject to + * removal in a future release. Consequently, this API is also deprecated and subject to removal. There is no replacement. + * * @since 1.5 */ -@SuppressWarnings("serial") // Externalizable class w/o no-arg c'tor +@Deprecated(since="20", forRemoval=true) +@SuppressWarnings({"serial", "removal"}) // Externalizable class w/o no-arg c'tor public class PrivateMLet extends MLet implements PrivateClassLoader { private static final long serialVersionUID = 2503458973393711979L; diff --git a/test/jdk/javax/management/Introspector/ClassLeakTest.java b/test/jdk/javax/management/Introspector/ClassLeakTest.java index 9a08c04b0c2..f6316f7e2c3 100644 --- a/test/jdk/javax/management/Introspector/ClassLeakTest.java +++ b/test/jdk/javax/management/Introspector/ClassLeakTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2022, 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 @@ -56,6 +56,7 @@ public class ClassLeakTest { urls[i] = Paths.get(cpaths[i]).toUri().toURL(); } + @SuppressWarnings("removal") PrivateMLet mlet = new PrivateMLet(urls, null, false); Class shadowClass = mlet.loadClass(TestMBean.class.getName()); if (shadowClass == TestMBean.class) { diff --git a/test/jdk/javax/management/MBeanServer/PostExceptionTest.java b/test/jdk/javax/management/MBeanServer/PostExceptionTest.java index 3e3c802fc88..a004acceee5 100644 --- a/test/jdk/javax/management/MBeanServer/PostExceptionTest.java +++ b/test/jdk/javax/management/MBeanServer/PostExceptionTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2022, 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 @@ -432,6 +432,7 @@ public class PostExceptionTest { if (server.isRegistered(name)) { return name; } + @SuppressWarnings("removal") final MLet mlet = new MLet(new URL[0], ClassLoader.getSystemClassLoader()); return server.registerMBean(mlet, name).getObjectName(); diff --git a/test/jdk/javax/management/loading/DocumentRootTest.java b/test/jdk/javax/management/loading/DocumentRootTest.java index ae598ddd99e..73b1654d135 100644 --- a/test/jdk/javax/management/loading/DocumentRootTest.java +++ b/test/jdk/javax/management/loading/DocumentRootTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2006, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2006, 2022, 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 @@ -38,6 +38,7 @@ import java.util.ArrayList; import java.util.HashMap; import javax.management.loading.MLetContent; +@SuppressWarnings("removal") public class DocumentRootTest { public static int test(URL documentBase, URL codeBase) { int error = 0; diff --git a/test/jdk/javax/management/loading/GetMBeansFromURLTest.java b/test/jdk/javax/management/loading/GetMBeansFromURLTest.java index 5f4d889c91b..31b86c72e8d 100644 --- a/test/jdk/javax/management/loading/GetMBeansFromURLTest.java +++ b/test/jdk/javax/management/loading/GetMBeansFromURLTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2004, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2004, 2022, 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 @@ -40,6 +40,7 @@ import javax.management.ObjectName; import javax.management.ServiceNotFoundException; import javax.management.loading.MLet; +@SuppressWarnings("removal") public class GetMBeansFromURLTest { public static void main(String[] args) throws Exception { diff --git a/test/jdk/javax/management/loading/MLetCLR/MLetCommand.java b/test/jdk/javax/management/loading/MLetCLR/MLetCommand.java index 2519f4329b2..2973b15c2cb 100644 --- a/test/jdk/javax/management/loading/MLetCLR/MLetCommand.java +++ b/test/jdk/javax/management/loading/MLetCLR/MLetCommand.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2022, 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 @@ -39,6 +39,7 @@ import javax.management.MBeanServerFactory; import javax.management.ObjectName; import java.io.File; +@SuppressWarnings("removal") public class MLetCommand { public static void main(String[] args) throws Exception { diff --git a/test/jdk/javax/management/loading/MLetContentTest.java b/test/jdk/javax/management/loading/MLetContentTest.java index 0fa9ce939f7..455a20533be 100644 --- a/test/jdk/javax/management/loading/MLetContentTest.java +++ b/test/jdk/javax/management/loading/MLetContentTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2004, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2004, 2022, 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 @@ -37,6 +37,7 @@ import java.net.*; import javax.management.loading.*; +@SuppressWarnings("removal") public class MLetContentTest { public static void main(String[] args) throws Exception { System.out.println(">>> General test for the public class MLetContent."); diff --git a/test/jdk/javax/management/loading/MLetInternalsTest.java b/test/jdk/javax/management/loading/MLetInternalsTest.java index 4d312728dcf..2007e68fddc 100644 --- a/test/jdk/javax/management/loading/MLetInternalsTest.java +++ b/test/jdk/javax/management/loading/MLetInternalsTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2022, 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 @@ -39,6 +39,7 @@ import static org.testng.Assert.*; * @modules java.management/javax.management.loading:open * @run testng MLetInternalsTest */ +@SuppressWarnings("removal") public class MLetInternalsTest { private final static String CONSTRUCT_PARAMETER = "constructParameter"; diff --git a/test/jdk/javax/management/loading/MletParserLocaleTest.java b/test/jdk/javax/management/loading/MletParserLocaleTest.java index 065fd45d854..4242caad0a2 100644 --- a/test/jdk/javax/management/loading/MletParserLocaleTest.java +++ b/test/jdk/javax/management/loading/MletParserLocaleTest.java @@ -39,6 +39,7 @@ import javax.management.MBeanServerFactory; import javax.management.ObjectName; import javax.management.loading.MLet; +@SuppressWarnings("removal") public class MletParserLocaleTest { public static void main(String[] args) throws Exception { diff --git a/test/jdk/javax/management/loading/ParserInfiniteLoopTest.java b/test/jdk/javax/management/loading/ParserInfiniteLoopTest.java index f02455826b4..4881d75556c 100644 --- a/test/jdk/javax/management/loading/ParserInfiniteLoopTest.java +++ b/test/jdk/javax/management/loading/ParserInfiniteLoopTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2022, 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 @@ -45,6 +45,7 @@ import javax.management.ObjectName; import javax.management.ServiceNotFoundException; import javax.management.loading.MLet; +@SuppressWarnings("removal") public class ParserInfiniteLoopTest { public static void main(String[] args) throws Exception { diff --git a/test/jdk/javax/management/mxbean/MXBeanLoadingTest1.java b/test/jdk/javax/management/mxbean/MXBeanLoadingTest1.java index 3a02ea262b5..a677133ea50 100644 --- a/test/jdk/javax/management/mxbean/MXBeanLoadingTest1.java +++ b/test/jdk/javax/management/mxbean/MXBeanLoadingTest1.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2022, 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 @@ -81,6 +81,7 @@ public class MXBeanLoadingTest1 { + ".class", ""); URL[] urls = new URL[]{new URL(clsLoadPath)}; + @SuppressWarnings("removal") PrivateMLet mlet = new PrivateMLet(urls, null, false); Class shadowClass = mlet.loadClass(TestMXBean.class.getName()); @@ -266,6 +267,7 @@ public class MXBeanLoadingTest1 { mbs.unregisterMBean(testName); mbs.unregisterMBean(mletName); + @SuppressWarnings("removal") WeakReference mletRef = new WeakReference(mlet); mlet = null; diff --git a/test/jdk/javax/management/relation/NonArrayListTest.java b/test/jdk/javax/management/relation/NonArrayListTest.java index 0304c198333..0bb75f7ca8a 100644 --- a/test/jdk/javax/management/relation/NonArrayListTest.java +++ b/test/jdk/javax/management/relation/NonArrayListTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2022, 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 @@ -38,6 +38,8 @@ import javax.management.relation.*; import javax.management.loading.MLet; public class NonArrayListTest { + + @SuppressWarnings("removal") // use of MLet public static void main(String[] args) throws Exception { MBeanServer mbs = MBeanServerFactory.createMBeanServer(); RelationService rs = new RelationService(true); diff --git a/test/jdk/javax/management/remote/mandatory/loading/TargetMBeanTest.java b/test/jdk/javax/management/remote/mandatory/loading/TargetMBeanTest.java index 9d949995351..1908a31e2de 100644 --- a/test/jdk/javax/management/remote/mandatory/loading/TargetMBeanTest.java +++ b/test/jdk/javax/management/remote/mandatory/loading/TargetMBeanTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2022, 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 @@ -101,6 +101,7 @@ public class TargetMBeanTest { URLClassLoader jrcl = (URLClassLoader) jmxRemoteClassLoader; URL[] urls = jrcl.getURLs(); + @SuppressWarnings("removal") PrivateMLet mlet = new PrivateMLet(urls, null, false); Class shadowClass = mlet.loadClass(JMXServiceURL.class.getName()); if (shadowClass == JMXServiceURL.class) { diff --git a/test/jdk/javax/management/remote/mandatory/notif/NotificationBufferTest.java b/test/jdk/javax/management/remote/mandatory/notif/NotificationBufferTest.java index bf8c1639486..6d21127bf25 100644 --- a/test/jdk/javax/management/remote/mandatory/notif/NotificationBufferTest.java +++ b/test/jdk/javax/management/remote/mandatory/notif/NotificationBufferTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2022, 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 @@ -80,6 +80,7 @@ public class NotificationBufferTest { } } + @SuppressWarnings("removal") // use of MLet private static boolean test() throws Exception { MBeanServer mbs = MBeanServerFactory.createMBeanServer();