From 5bf8a6f44b832496c62ee0008b9087588faf1fc5 Mon Sep 17 00:00:00 2001 From: Jan Lahoda Date: Thu, 14 Jun 2018 13:16:21 +0200 Subject: [PATCH] 8196618: Create API to list supported values for javac --release option 8194308: jdeprscan will need updates to deal with the removal of the Java EE modules Generalizing tests to run over all supported --release keys; fixing jdeprscan to work with --release 11. Reviewed-by: smarks, vromero --- .../com/sun/tools/javac/main/Option.java | 2 +- .../javac/platform/JDKPlatformProvider.java | 20 ++++++- .../classes/com/sun/tools/jdeprscan/Main.java | 37 +++++++++--- .../jdeprscan/resources/jdeprscan.properties | 2 +- test/langtools/ProblemList.txt | 8 --- .../tools/javac/modules/JavaBaseTest.java | 20 +++++-- .../platform/NumericalComparatorTest.java | 58 +++++++++++++++++++ .../tests/jdk/jdeprscan/TestRelease.java | 18 +++--- 8 files changed, 133 insertions(+), 32 deletions(-) create mode 100644 test/langtools/tools/javac/platform/NumericalComparatorTest.java diff --git a/src/jdk.compiler/share/classes/com/sun/tools/javac/main/Option.java b/src/jdk.compiler/share/classes/com/sun/tools/javac/main/Option.java index ca7188fe7e9..5e1edf499f8 100644 --- a/src/jdk.compiler/share/classes/com/sun/tools/javac/main/Option.java +++ b/src/jdk.compiler/share/classes/com/sun/tools/javac/main/Option.java @@ -317,7 +317,7 @@ public enum Option { .flatMap(provider -> StreamSupport.stream(provider.getSupportedPlatformNames() .spliterator(), false)) - .collect(Collectors.toCollection(TreeSet :: new)); + .collect(Collectors.toCollection(LinkedHashSet :: new)); StringBuilder targets = new StringBuilder(); String delim = ""; diff --git a/src/jdk.compiler/share/classes/com/sun/tools/javac/platform/JDKPlatformProvider.java b/src/jdk.compiler/share/classes/com/sun/tools/javac/platform/JDKPlatformProvider.java index fbb7cc57d05..22fa43c991d 100644 --- a/src/jdk.compiler/share/classes/com/sun/tools/javac/platform/JDKPlatformProvider.java +++ b/src/jdk.compiler/share/classes/com/sun/tools/javac/platform/JDKPlatformProvider.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2018, 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 java.nio.file.ProviderNotFoundException; import java.util.ArrayList; import java.util.Arrays; import java.util.Collections; +import java.util.Comparator; import java.util.EnumSet; import java.util.HashMap; import java.util.Iterator; @@ -89,9 +90,24 @@ public class JDKPlatformProvider implements PlatformProvider { private static final String[] symbolFileLocation = { "lib", "ct.sym" }; private static final Set SUPPORTED_JAVA_PLATFORM_VERSIONS; + public static final Comparator NUMERICAL_COMPARATOR = (s1, s2) -> { + int i1; + try { + i1 = Integer.parseInt(s1); + } catch (NumberFormatException ex) { + i1 = Integer.MAX_VALUE; + } + int i2; + try { + i2 = Integer.parseInt(s2); + } catch (NumberFormatException ex) { + i2 = Integer.MAX_VALUE; + } + return i1 != i2 ? i1 - i2 : s1.compareTo(s2); + }; static { - SUPPORTED_JAVA_PLATFORM_VERSIONS = new TreeSet<>(); + SUPPORTED_JAVA_PLATFORM_VERSIONS = new TreeSet<>(NUMERICAL_COMPARATOR); Path ctSymFile = findCtSym(); if (Files.exists(ctSymFile)) { try (FileSystem fs = FileSystems.newFileSystem(ctSymFile, null); diff --git a/src/jdk.jdeps/share/classes/com/sun/tools/jdeprscan/Main.java b/src/jdk.jdeps/share/classes/com/sun/tools/jdeprscan/Main.java index 7eda6cc5e8b..456165a423b 100644 --- a/src/jdk.jdeps/share/classes/com/sun/tools/jdeprscan/Main.java +++ b/src/jdk.jdeps/share/classes/com/sun/tools/jdeprscan/Main.java @@ -335,7 +335,7 @@ public class Main implements DiagnosticListener { */ boolean processSelf(Collection classes) throws IOException { options.add("--add-modules"); - options.add("java.se.ee,jdk.xml.bind"); // TODO why jdk.xml.bind? + options.add("java.se"); if (classes.isEmpty()) { Path modules = FileSystems.getFileSystem(URI.create("jrt:/")) @@ -358,21 +358,35 @@ public class Main implements DiagnosticListener { * Process classes from a particular JDK release, using only information * in this JDK. * - * @param release "6", "7", "8", "9", "10", or "11" + * @param release a supported release version, like "8" or "10". * @param classes collection of classes to process, may be empty * @return success value */ boolean processRelease(String release, Collection classes) throws IOException { + boolean hasModules; + boolean hasJavaSE_EE; + + try { + int releaseNum = Integer.parseInt(release); + + hasModules = releaseNum >= 9; + hasJavaSE_EE = hasModules && releaseNum <= 10; + } catch (NumberFormatException ex) { + hasModules = true; + hasJavaSE_EE = false; + } + options.addAll(List.of("--release", release)); - if (release.equals("9") || release.equals("10") || - release.equals("11")) { - List rootMods = List.of("java.se", "java.se.ee"); + if (hasModules) { + List rootMods = hasJavaSE_EE ? List.of("java.se", "java.se.ee") + : List.of("java.se"); TraverseProc proc = new TraverseProc(rootMods); JavaCompiler.CompilationTask task = compiler.getTask(null, fm, this, // options - List.of("--add-modules", String.join(",", rootMods)), + List.of("--add-modules", String.join(",", rootMods), + "--release", release), // classes List.of("java.lang.Object"), null); @@ -507,7 +521,7 @@ public class Main implements DiagnosticListener { case "--help": case "-h": case "-?": - out.println(Messages.get("main.usage")); + printHelp(out); out.println(); out.println(Messages.get("main.help")); return true; @@ -624,7 +638,7 @@ public class Main implements DiagnosticListener { return false; } } catch (NoSuchElementException | UsageException ex) { - err.println(Messages.get("main.usage")); + printHelp(err); return false; } catch (IOException ioe) { if (verbose) { @@ -680,6 +694,13 @@ public class Main implements DiagnosticListener { return scanStatus; } + private void printHelp(PrintStream out) { + JDKPlatformProvider pp = new JDKPlatformProvider(); + String supportedReleases = + String.join("|", pp.getSupportedPlatformNames()); + out.println(Messages.get("main.usage", supportedReleases)); + } + /** * Programmatic main entry point: initializes the tool instance to * use stdout and stderr; runs the tool, passing command-line args; diff --git a/src/jdk.jdeps/share/classes/com/sun/tools/jdeprscan/resources/jdeprscan.properties b/src/jdk.jdeps/share/classes/com/sun/tools/jdeprscan/resources/jdeprscan.properties index 1ebb3a65acb..1d3966849c6 100644 --- a/src/jdk.jdeps/share/classes/com/sun/tools/jdeprscan/resources/jdeprscan.properties +++ b/src/jdk.jdeps/share/classes/com/sun/tools/jdeprscan/resources/jdeprscan.properties @@ -7,7 +7,7 @@ options:\n\ \ --full-version\n\ \ -? -h --help\n\ \ -l --list\n\ -\ --release 6|7|8|9|10\n\ +\ --release {0}\n\ \ -v --verbose\n\ \ --version diff --git a/test/langtools/ProblemList.txt b/test/langtools/ProblemList.txt index 1ca93245d58..69e4c952be7 100644 --- a/test/langtools/ProblemList.txt +++ b/test/langtools/ProblemList.txt @@ -81,11 +81,3 @@ tools/sjavac/ClasspathDependencies.java 8158002 generic-all Requires i # # jdeps -tools/jdeprscan/tests/jdk/jdeprscan/TestNotFound.java 8193784 generic-all temporary until support for --release 11 is worked out -########################################################################### -# -# Java EE Module Removal -# -tools/jdeprscan/tests/jdk/jdeprscan/TestRelease.java 8194308 generic-all Java EE Module Removal -tools/jdeprscan/tests/jdk/jdeprscan/TestNotFound.java 8194308 generic-all Java EE Module Removal - diff --git a/test/langtools/tools/javac/modules/JavaBaseTest.java b/test/langtools/tools/javac/modules/JavaBaseTest.java index 69d22403c4c..0f9ebb78ec4 100644 --- a/test/langtools/tools/javac/modules/JavaBaseTest.java +++ b/test/langtools/tools/javac/modules/JavaBaseTest.java @@ -28,7 +28,9 @@ * @library /tools/lib * @modules * jdk.compiler/com.sun.tools.javac.api + * jdk.compiler/com.sun.tools.javac.jvm * jdk.compiler/com.sun.tools.javac.main + * jdk.compiler/com.sun.tools.javac.platform * jdk.jdeps/com.sun.tools.classfile * @build toolbox.ToolBox toolbox.JavacTask * @run main JavaBaseTest @@ -37,10 +39,12 @@ import java.nio.file.Files; import java.nio.file.Path; import java.nio.file.Paths; -import java.util.Arrays; import java.util.LinkedHashMap; +import java.util.LinkedHashSet; import java.util.List; import java.util.Map; +import java.util.Set; +import java.util.stream.StreamSupport; import com.sun.tools.classfile.Attribute; import com.sun.tools.classfile.Attributes; @@ -48,9 +52,11 @@ import com.sun.tools.classfile.ClassFile; import com.sun.tools.classfile.ClassWriter; import com.sun.tools.classfile.Module_attribute; +import com.sun.tools.javac.jvm.Target; +import com.sun.tools.javac.platform.JDKPlatformProvider; + import toolbox.JavacTask; import toolbox.Task; -import toolbox.Task.Expect; import toolbox.ToolBox; public class JavaBaseTest { @@ -66,8 +72,6 @@ public class JavaBaseTest { List.of("static", "transitive") ); - final List targets = List.of("9", "10", "current"); - enum Mode { SOURCE, CLASS }; ToolBox tb = new ToolBox(); @@ -75,6 +79,14 @@ public class JavaBaseTest { int errorCount = 0; void run() throws Exception { + Set targets = new LinkedHashSet<>(); + StreamSupport.stream(new JDKPlatformProvider().getSupportedPlatformNames() + .spliterator(), + false) + .filter(p -> Integer.parseInt(p) >= 9) + .forEach(targets::add); + //run without --release: + targets.add("current"); for (List mods : modifiers) { for (String target : targets) { for (Mode mode : Mode.values()) { diff --git a/test/langtools/tools/javac/platform/NumericalComparatorTest.java b/test/langtools/tools/javac/platform/NumericalComparatorTest.java new file mode 100644 index 00000000000..4664988816f --- /dev/null +++ b/test/langtools/tools/javac/platform/NumericalComparatorTest.java @@ -0,0 +1,58 @@ +/* + * Copyright (c) 2018, 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 8196618 + * @summary Check that JDKPlatformProvider.NUMERICAL_COMPARATOR works correctly + * @library /tools/lib + * @modules jdk.compiler/com.sun.tools.javac.platform + * @run main NumericalComparatorTest + */ + +import java.io.IOException; +import java.util.List; +import java.util.stream.Collectors; + +import com.sun.tools.javac.platform.JDKPlatformProvider; + +public class NumericalComparatorTest { + + public static void main(String... args) throws IOException { + new NumericalComparatorTest().run(); + } + + void run() throws IOException { + doTest(List.of("8", "10", "11", "9", "b1", "a1", "a2"), + List.of("8", "9", "10", "11", "a1", "a2", "b1")); + } + + void doTest(List input, List expectedOutput) { + List actual = input.stream() + .sorted(JDKPlatformProvider.NUMERICAL_COMPARATOR) + .collect(Collectors.toList()); + if (!expectedOutput.equals(actual)) + throw new AssertionError("Unexpected output: " + actual); + } + +} diff --git a/test/langtools/tools/jdeprscan/tests/jdk/jdeprscan/TestRelease.java b/test/langtools/tools/jdeprscan/tests/jdk/jdeprscan/TestRelease.java index c3c2d879431..ee2fb4a6a59 100644 --- a/test/langtools/tools/jdeprscan/tests/jdk/jdeprscan/TestRelease.java +++ b/test/langtools/tools/jdeprscan/tests/jdk/jdeprscan/TestRelease.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2016, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 2018, 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 @@ -23,15 +23,19 @@ /* * @test - * @bug 8167965 + * @bug 8167965 8194308 * @summary Test proper handling of the --release option. - * @modules jdk.jdeps/com.sun.tools.jdeprscan + * @modules + * jdk.compiler/com.sun.tools.javac.jvm + * jdk.compiler/com.sun.tools.javac.platform + * jdk.jdeps/com.sun.tools.jdeprscan * @build jdk.jdeprscan.TestRelease * @run testng jdk.jdeprscan.TestRelease */ package jdk.jdeprscan; +import com.sun.tools.javac.platform.JDKPlatformProvider; import com.sun.tools.jdeprscan.Main; import org.testng.annotations.Test; @@ -45,11 +49,9 @@ public class TestRelease { @Test public void testSuccess() { - assertTrue(invoke("6")); - assertTrue(invoke("7")); - assertTrue(invoke("8")); - assertTrue(invoke("9")); - assertTrue(invoke("10")); + for (String target : new JDKPlatformProvider().getSupportedPlatformNames()) { + assertTrue(invoke(target)); + } } @Test