From 065fdac559b1c409e8fec1608d97ab01e854ad09 Mon Sep 17 00:00:00 2001 From: Jonathan Gibbons Date: Wed, 26 Sep 2018 15:14:17 -0700 Subject: [PATCH] 8210555: create --source --target synonyms for -source -target Reviewed-by: hannesw --- .../com/sun/tools/javac/main/Option.java | 4 +- .../com/sun/tools/javadoc/main/Start.java | 4 +- .../sun/tools/javadoc/main/ToolOption.java | 7 ++ .../jdk/javadoc/internal/tool/ToolOption.java | 2 +- .../tool/api/basic/IsSupportedOptionTest.java | 6 +- .../tool/sourceOption/SourceOption.java | 27 +++----- .../javac/options/IsSupportedOptionTest.java | 5 +- .../api/basic/IsSupportedOptionTest.java | 69 ------------------- .../javadoc/sourceOption/SourceOption.java | 27 +++----- 9 files changed, 42 insertions(+), 109 deletions(-) delete mode 100644 test/langtools/tools/javadoc/api/basic/IsSupportedOptionTest.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 ac857dbaa9b..809b1cff7fe 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 @@ -328,7 +328,7 @@ public enum Option { ENCODING("-encoding", "opt.arg.encoding", "opt.encoding", STANDARD, FILEMANAGER), - SOURCE("-source", "opt.arg.release", "opt.source", STANDARD, BASIC) { + SOURCE("--source -source", "opt.arg.release", "opt.source", STANDARD, BASIC) { @Override public void process(OptionHelper helper, String option, String operand) throws InvalidValueException { Source source = Source.lookup(operand); @@ -349,7 +349,7 @@ public enum Option { } }, - TARGET("-target", "opt.arg.release", "opt.target", STANDARD, BASIC) { + TARGET("--target -target", "opt.arg.release", "opt.target", STANDARD, BASIC) { @Override public void process(OptionHelper helper, String option, String operand) throws InvalidValueException { Target target = Target.lookup(operand); diff --git a/src/jdk.javadoc/share/classes/com/sun/tools/javadoc/main/Start.java b/src/jdk.javadoc/share/classes/com/sun/tools/javadoc/main/Start.java index 00f0e3f8e5f..1e55c268333 100644 --- a/src/jdk.javadoc/share/classes/com/sun/tools/javadoc/main/Start.java +++ b/src/jdk.javadoc/share/classes/com/sun/tools/javadoc/main/Start.java @@ -380,8 +380,8 @@ public class Start extends ToolOption.Helper { String platformString = compOpts.get("--release"); if (platformString != null) { - if (compOpts.isSet("-source")) { - usageError("main.release.bootclasspath.conflict", "-source"); + if (compOpts.isSet(Option.SOURCE.primaryName)) { + usageError("main.release.bootclasspath.conflict", Option.SOURCE.primaryName); } if (fileManagerOpts.containsKey(Option.BOOT_CLASS_PATH)) { usageError("main.release.bootclasspath.conflict", Option.BOOT_CLASS_PATH.getPrimaryName()); diff --git a/src/jdk.javadoc/share/classes/com/sun/tools/javadoc/main/ToolOption.java b/src/jdk.javadoc/share/classes/com/sun/tools/javadoc/main/ToolOption.java index 309bf3601b0..5606296771b 100644 --- a/src/jdk.javadoc/share/classes/com/sun/tools/javadoc/main/ToolOption.java +++ b/src/jdk.javadoc/share/classes/com/sun/tools/javadoc/main/ToolOption.java @@ -172,6 +172,13 @@ public enum ToolOption { }, SOURCE("-source", true) { + @Override + public void process(Helper helper, String arg) { + helper.setCompilerOpt("--source", arg); + } + }, + + SOURCE2("--source", true) { @Override public void process(Helper helper, String arg) { helper.setCompilerOpt(opt, arg); diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/tool/ToolOption.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/tool/ToolOption.java index 81390c4b2c1..7e510fb5099 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/tool/ToolOption.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/tool/ToolOption.java @@ -146,7 +146,7 @@ public enum ToolOption { } }, - SOURCE("-source", STANDARD, true) { + SOURCE("--source -source", STANDARD, true) { @Override public void process(Helper helper, String arg) throws InvalidValueException { Option.SOURCE.process(helper.getOptionHelper(), primaryName, arg); diff --git a/test/langtools/jdk/javadoc/tool/api/basic/IsSupportedOptionTest.java b/test/langtools/jdk/javadoc/tool/api/basic/IsSupportedOptionTest.java index a9cc03a8f97..2e34548e0f8 100644 --- a/test/langtools/jdk/javadoc/tool/api/basic/IsSupportedOptionTest.java +++ b/test/langtools/jdk/javadoc/tool/api/basic/IsSupportedOptionTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 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,7 +23,7 @@ /* * @test - * @bug 6493690 + * @bug 6493690 8210555 * @summary javadoc should have a javax.tools.Tool service provider * @modules java.compiler * jdk.compiler @@ -48,6 +48,8 @@ public class IsSupportedOptionTest extends APITest { @Test public void test() throws Exception { DocumentationTool tool = ToolProvider.getSystemDocumentationTool(); + check(tool, "-source", 1); + check(tool, "--source", 1); check(tool, "-sourcepath", 1); check(tool, "-verbose", 0); check(tool, "-ZZZ", -1); diff --git a/test/langtools/jdk/javadoc/tool/sourceOption/SourceOption.java b/test/langtools/jdk/javadoc/tool/sourceOption/SourceOption.java index 4798aa178b9..883eb80dde4 100644 --- a/test/langtools/jdk/javadoc/tool/sourceOption/SourceOption.java +++ b/test/langtools/jdk/javadoc/tool/sourceOption/SourceOption.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2006, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2006, 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 @@ -33,25 +33,20 @@ */ /* - * TEST NOTE - * With JDK9, this test has been transformed into a NEGATIVE test. + * In order to test whether or not the -source option is working + * correctly, this test tries to parse source code that contains + * a feature that is not available in at least one of the currently + * supported previous versions. * - * Generally speaking, this test should check a feature not in at least - * one of the currently supported previous versions. In this manner, - * a failure of the -source option to be honored would mean a pass of - * the test, and therefore a failure of the -source option. + * Parsing such code should be expected to fail; if the action + * passes, that means the -source option is (incorrectly) ineffective. * - * For JDK9 and JDK10, both support 1.7, which did not support javac's - * lambda construct. So we set "-source 1.7" to compile a .java file - * containing the lambda construct. javac should fail, thus showing - * -source to be working. Thus the test passes. - * - * The second jtreg @run command checks to make sure that the source + * Additional actions are performed to ensure that the source * provided is valid for the current release of the JDK. * - * fixVersion: JDK11 - * replace ./p/LambdaConstructTest.java with a missing from - * JDK8, JDK9, or JDK10. Set -source below appropriately. + * As support for older versions of the platform are dropped, the + * source code (currently p/LambdaConstructTest.java) will need to + * be updated with a more recent feature. */ import java.util.ArrayList; diff --git a/test/langtools/tools/javac/options/IsSupportedOptionTest.java b/test/langtools/tools/javac/options/IsSupportedOptionTest.java index b70230e34dc..f4b44a567d6 100644 --- a/test/langtools/tools/javac/options/IsSupportedOptionTest.java +++ b/test/langtools/tools/javac/options/IsSupportedOptionTest.java @@ -23,7 +23,7 @@ /* * @test - * @bug 8189782 + * @bug 8189782 8210555 * @summary Test for isSupportedOption * @modules java.compiler * jdk.compiler @@ -44,6 +44,9 @@ public class IsSupportedOptionTest { public void run() throws Exception { JavaCompiler tool = ToolProvider.getSystemJavaCompiler(); check(tool, "-source", 1); + check(tool, "--source", 1); + check(tool, "-target", 1); + check(tool, "--target", 1); check(tool, "--add-modules", 1); check(tool, "-verbose", 0); check(tool, "-proc:none", 0); diff --git a/test/langtools/tools/javadoc/api/basic/IsSupportedOptionTest.java b/test/langtools/tools/javadoc/api/basic/IsSupportedOptionTest.java deleted file mode 100644 index 2f1dd8ed7fa..00000000000 --- a/test/langtools/tools/javadoc/api/basic/IsSupportedOptionTest.java +++ /dev/null @@ -1,69 +0,0 @@ -/* - * Copyright (c) 2012, 2015, 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 6493690 - * @summary javadoc should have a javax.tools.Tool service provider - * @modules java.compiler - * jdk.compiler - * @build APITest - * @run main IsSupportedOptionTest - */ - -import javax.tools.DocumentationTool; -import javax.tools.ToolProvider; - -/** - * Tests for DocumentationTool.usSupportedOption method. - */ -public class IsSupportedOptionTest extends APITest { - public static void main(String... args) throws Exception { - new IsSupportedOptionTest().run(); - } - - /** - * Verify that isSupportedOption method can be invoked. - */ - @Test - public void test() throws Exception { - DocumentationTool tool = ToolProvider.getSystemDocumentationTool(); - check(tool, "-sourcepath", 1); - check(tool, "-verbose", 0); - check(tool, "-ZZZ", -1); - - try { - check(tool, null, -1); - error("null was accepted without exception"); - } catch (NullPointerException e) { - } - } - - private void check(DocumentationTool tool, String option, int numArgs) { - System.err.println("check " + option); - int n = tool.isSupportedOption(option); - if (n != numArgs) - error("unexpected result for option: " + option + ": " + n); - } -} - diff --git a/test/langtools/tools/javadoc/sourceOption/SourceOption.java b/test/langtools/tools/javadoc/sourceOption/SourceOption.java index 35c3be6f8e5..bcfa3f61d71 100644 --- a/test/langtools/tools/javadoc/sourceOption/SourceOption.java +++ b/test/langtools/tools/javadoc/sourceOption/SourceOption.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2006, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2006, 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 @@ -33,25 +33,20 @@ */ /* - * TEST NOTE - * With JDK9, this test has been transformed into a NEGATIVE test. + * In order to test whether or not the -source option is working + * correctly, this test tries to parse source code that contains + * a feature that is not available in at least one of the currently + * supported previous versions. * - * Generally speaking, this test should check a feature not in at least - * one of the currently supported previous versions. In this manner, - * a failure of the -source option to be honored would mean a pass of - * the test, and therefore a failure of the -source option. + * Parsing such code should be expected to fail; if the action + * passes, that means the -source option is (incorrectly) ineffective. * - * For JDK9 and JDK10, both support 1.7, which did not support javac's - * lambda construct. So we set "-source 1.7" to compile a .java file - * containing the lambda construct. javac should fail, thus showing - * -source to be working. Thus the test passes. - * - * The second jtreg @run command checks to make sure that the source + * Additional actions are performed to ensure that the source * provided is valid for the current release of the JDK. * - * fixVersion: JDK11 - * replace ./p/LambdaConstructTest.java with a missing from - * JDK8, JDK9, or JDK10. Set -source below appropriately. + * As support for older versions of the platform are dropped, the + * source code (currently p/LambdaConstructTest.java) will need to + * be updated with a more recent feature. */ import com.sun.javadoc.*;