--- old/src/java.compiler/share/classes/javax/annotation/processing/RoundEnvironment.java 2016-06-12 22:35:47.384024170 -0700 +++ new/src/java.compiler/share/classes/javax/annotation/processing/RoundEnvironment.java 2016-06-12 22:35:47.252024176 -0700 @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2007, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2016, 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 @@ -103,7 +103,7 @@ * * @implSpec The default implementation of this method creates an * empty result set, iterates over the annotations in the argument - * set calling {@link #getElementsAnnotatedWith(TypeElement)} on + * array calling {@link #getElementsAnnotatedWith(TypeElement)} on * each annotation and adding those results to the result * set. Finally, the contents of the result set are returned as an * unmodifiable set. --- old/src/java.compiler/share/classes/javax/tools/ToolProvider.java 2016-06-12 22:35:47.680024156 -0700 +++ new/src/java.compiler/share/classes/javax/tools/ToolProvider.java 2016-06-12 22:35:47.600024160 -0700 @@ -125,9 +125,8 @@ private static T getSystemTool(Class clazz, String moduleName, String className) { if (useLegacy) { try { - @SuppressWarnings("deprecation") - T result = Class.forName(className, true, ClassLoader.getSystemClassLoader()).asSubclass(clazz).newInstance(); - return result; + return Class.forName(className, true, ClassLoader.getSystemClassLoader()). + asSubclass(clazz).getConstructor().newInstance(); } catch (ReflectiveOperationException e) { throw new Error(e); } --- old/src/jdk.compiler/share/classes/com/sun/tools/javac/processing/JavacProcessingEnvironment.java 2016-06-12 22:35:47.956024143 -0700 +++ new/src/jdk.compiler/share/classes/com/sun/tools/javac/processing/JavacProcessingEnvironment.java 2016-06-12 22:35:47.864024148 -0700 @@ -31,6 +31,7 @@ import java.io.PrintWriter; import java.io.StringWriter; import java.lang.reflect.Method; +import java.lang.reflect.Constructor; import java.net.MalformedURLException; import java.net.URL; import java.nio.file.Path; @@ -282,9 +283,7 @@ if (options.isSet(XPRINT)) { try { - @SuppressWarnings("deprecation") - Processor processor = PrintingProcessor.class.newInstance(); - processorIterator = List.of(processor).iterator(); + processorIterator = List.of(new PrintingProcessor()).iterator(); } catch (Throwable t) { AssertionError assertError = new AssertionError("Problem instantiating PrintingProcessor."); @@ -540,38 +539,40 @@ if (nextProc != null) return true; else { - if (!names.hasNext()) + if (!names.hasNext()) { return false; - else { - String processorName = names.next(); - - Processor processor; - try { - try { - Class processorClass = processorCL.loadClass(processorName); - ensureReadable(processorClass); - @SuppressWarnings("deprecation") - Object tmp = processorClass.newInstance(); - processor = (Processor) tmp; - } catch (ClassNotFoundException cnfe) { - log.error("proc.processor.not.found", processorName); - return false; - } catch (ClassCastException cce) { - log.error("proc.processor.wrong.type", processorName); - return false; - } catch (Exception e ) { - log.error("proc.processor.cant.instantiate", processorName); - return false; - } - } catch(ClientCodeException e) { - throw e; - } catch(Throwable t) { - throw new AnnotationProcessingError(t); + } else { + Processor processor = getNextProcessor(names.next()); + if (processor == null) { + return false; + } else { + nextProc = processor; + return true; } - nextProc = processor; - return true; } + } + } + private Processor getNextProcessor(String processorName) { + try { + try { + Class processorClass = processorCL.loadClass(processorName); + ensureReadable(processorClass); + return (Processor) processorClass.getConstructor().newInstance(); + } catch (ClassNotFoundException cnfe) { + log.error("proc.processor.not.found", processorName); + return null; + } catch (ClassCastException cce) { + log.error("proc.processor.wrong.type", processorName); + return null; + } catch (Exception e ) { + log.error("proc.processor.cant.instantiate", processorName); + return null; + } + } catch (ClientCodeException e) { + throw e; + } catch (Throwable t) { + throw new AnnotationProcessingError(t); } } --- old/src/jdk.compiler/share/classes/com/sun/tools/sjavac/options/Option.java 2016-06-12 22:35:48.240024130 -0700 +++ new/src/jdk.compiler/share/classes/com/sun/tools/sjavac/options/Option.java 2016-06-12 22:35:48.152024134 -0700 @@ -151,8 +151,8 @@ // Construct transformer try { Class trCls = Class.forName(classname); - @SuppressWarnings("deprecation") - Transformer transformer = (Transformer) trCls.newInstance(); + Transformer transformer = + (Transformer) trCls.getConstructor().newInstance(); transformer.setExtra(extra); helper.addTransformer(suffix, transformer); } catch (Exception e) { --- old/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/taglets/TagletManager.java 2016-06-12 22:35:48.508024118 -0700 +++ new/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/taglets/TagletManager.java 2016-06-12 22:35:48.420024122 -0700 @@ -252,8 +252,7 @@ } tagClassLoader = fileManager.getClassLoader(TAGLET_PATH); Class customTagClass = tagClassLoader.loadClass(classname); - @SuppressWarnings("deprecation") - Object instance = customTagClass.newInstance(); + Object instance = customTagClass.getConstructor().newInstance(); Taglet newLegacy = new UserTaglet((jdk.javadoc.doclet.taglet.Taglet)instance); String tname = newLegacy.getName(); Taglet t = customTags.get(tname); --- old/src/jdk.javadoc/share/classes/jdk/javadoc/internal/tool/Start.java 2016-06-12 22:35:48.776024105 -0700 +++ new/src/jdk.javadoc/share/classes/jdk/javadoc/internal/tool/Start.java 2016-06-12 22:35:48.692024109 -0700 @@ -273,9 +273,9 @@ initMessager(); messager.setLocale(locale); try { - Object o = docletClass.newInstance(); + Object o = docletClass.getConstructor().newInstance(); doclet = (Doclet) o; - } catch (InstantiationException | IllegalAccessException exc) { + } catch (ReflectiveOperationException exc) { exc.printStackTrace(); if (!apiMode) { error("main.could_not_instantiate_class", docletClass);