6595666: fix -Werror
Reviewed-by: mcimadamore
This commit is contained in:
parent
c597e8b844
commit
21507b2ba7
@ -371,6 +371,7 @@ public class JavaCompiler implements ClassReader.SourceCompleter {
|
||||
context.get(DiagnosticListener.class) != null;
|
||||
devVerbose = options.get("dev") != null;
|
||||
processPcks = options.get("process.packages") != null;
|
||||
werror = options.get("-Werror") != null;
|
||||
|
||||
verboseCompilePolicy = options.get("verboseCompilePolicy") != null;
|
||||
|
||||
@ -434,6 +435,10 @@ public class JavaCompiler implements ClassReader.SourceCompleter {
|
||||
*/
|
||||
protected boolean processPcks;
|
||||
|
||||
/** Switch: treat warnings as errors
|
||||
*/
|
||||
protected boolean werror;
|
||||
|
||||
/** Switch: is annotation processing requested explitly via
|
||||
* CompilationTask.setProcessors?
|
||||
*/
|
||||
@ -490,7 +495,11 @@ public class JavaCompiler implements ClassReader.SourceCompleter {
|
||||
public int errorCount() {
|
||||
if (delegateCompiler != null && delegateCompiler != this)
|
||||
return delegateCompiler.errorCount();
|
||||
else
|
||||
else {
|
||||
if (werror && log.nerrors == 0 && log.nwarnings > 0) {
|
||||
log.error("warnings.and.werror");
|
||||
}
|
||||
}
|
||||
return log.nerrors;
|
||||
}
|
||||
|
||||
|
@ -406,8 +406,7 @@ public class Main {
|
||||
}
|
||||
}
|
||||
|
||||
if (comp.errorCount() != 0 ||
|
||||
options.get("-Werror") != null && comp.warningCount() != 0)
|
||||
if (comp.errorCount() != 0)
|
||||
return EXIT_ERROR;
|
||||
} catch (IOException ex) {
|
||||
ioMessage(ex);
|
||||
|
@ -449,7 +449,7 @@ public class RecognizedOptions {
|
||||
},
|
||||
|
||||
// treat warnings as errors
|
||||
new HiddenOption(WERROR),
|
||||
new Option(WERROR, "opt.Werror"),
|
||||
|
||||
// use complex inference from context in the position of a method call argument
|
||||
new HiddenOption(COMPLEXINFERENCE),
|
||||
|
@ -346,6 +346,9 @@ compiler.err.pkg.annotations.sb.in.package-info.java=\
|
||||
compiler.err.pkg.clashes.with.class.of.same.name=\
|
||||
package {0} clashes with class of same name
|
||||
|
||||
compiler.err.warnings.and.werror=\
|
||||
warnings found and -Werror specified
|
||||
|
||||
# Errors related to annotation processing
|
||||
|
||||
compiler.err.proc.cant.access=\
|
||||
|
@ -69,6 +69,8 @@ javac.opt.target=\
|
||||
Generate class files for specific VM version
|
||||
javac.opt.source=\
|
||||
Provide source compatibility with specified release
|
||||
javac.opt.Werror=\
|
||||
Terminate compilation if warnings occur
|
||||
javac.opt.A=\
|
||||
Options to pass to annotation processors
|
||||
javac.opt.implicit=\
|
||||
|
@ -7,12 +7,7 @@ found : java.util.ArrayList
|
||||
required: java.util.List<java.lang.Integer>
|
||||
List<Integer> list = new ArrayList();
|
||||
^
|
||||
T6304921.java:445/445/453: warning: [fallthrough] possible fall-through into case
|
||||
default:
|
||||
^
|
||||
T6304921.java:522/613/614: warning: [finally] finally clause cannot complete normally
|
||||
}
|
||||
^
|
||||
error: warnings found and -Werror specified
|
||||
T6304921.java:727/733/737: cannot find symbol
|
||||
symbol : variable orr
|
||||
location: class java.lang.System
|
||||
@ -21,5 +16,5 @@ location: class java.lang.System
|
||||
T6304921.java:812/816/822: operator + cannot be applied to int,boolean
|
||||
return 123 + true; // bad binary expression
|
||||
^
|
||||
2 errors
|
||||
4 warnings
|
||||
3 errors
|
||||
2 warnings
|
||||
|
@ -1,3 +1,5 @@
|
||||
T6758789b.java:39:11: compiler.warn.prob.found.req: (- compiler.misc.unchecked.assign), T6758789a.Foo, T6758789a.Foo<X>
|
||||
T6758789b.java:39:10: compiler.warn.unchecked.meth.invocation.applied: kindname.method, m, T6758789a.Foo<X>, T6758789a.Foo, kindname.class, T6758789a
|
||||
- compiler.err.warnings.and.werror
|
||||
1 error
|
||||
2 warnings
|
||||
|
@ -2,4 +2,6 @@ T6241723.java:21:5: compiler.warn.has.been.deprecated: A1, unnamed package
|
||||
T6241723.java:23:7: compiler.warn.has.been.deprecated: A2.A21, A2
|
||||
T6241723.java:26:5: compiler.warn.has.been.deprecated: Z1, unnamed package
|
||||
T6241723.java:28:7: compiler.warn.has.been.deprecated: Z2.Z21, Z2
|
||||
- compiler.err.warnings.and.werror
|
||||
1 error
|
||||
4 warnings
|
||||
|
68
langtools/test/tools/javac/T6595666.java
Normal file
68
langtools/test/tools/javac/T6595666.java
Normal file
@ -0,0 +1,68 @@
|
||||
/*
|
||||
* Copyright 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
||||
* CA 95054 USA or visit www.sun.com if you need additional information or
|
||||
* have any questions.
|
||||
*/
|
||||
|
||||
/*
|
||||
* @test
|
||||
* @bug 6595666
|
||||
* @summary fix -Werror
|
||||
*/
|
||||
|
||||
import java.io.*;
|
||||
import java.util.*;
|
||||
|
||||
public class T6595666 {
|
||||
void m() {
|
||||
// the following line must create warnings with -Xlint, because of unchecked conversion
|
||||
List<Integer> list = new ArrayList();
|
||||
}
|
||||
|
||||
public static void main(String... args) throws Exception {
|
||||
File testSrc = new File(System.getProperty("test.src", "."));
|
||||
|
||||
String basename = T6595666.class.getName();
|
||||
File srcFile = new File(testSrc, basename+".java");
|
||||
File classFile = new File(basename+".class");
|
||||
classFile.delete();
|
||||
if (classFile.exists())
|
||||
throw new Exception("setup error, can't delete " + classFile);
|
||||
|
||||
compile(1, "-d", ".", "-Xlint", "-Werror", srcFile.getPath());
|
||||
if (classFile.exists())
|
||||
throw new Exception("failed: found " + classFile);
|
||||
|
||||
compile(0, "-d", ".", "-Xlint", srcFile.getPath());
|
||||
if (!classFile.exists())
|
||||
throw new Exception("failed: " + classFile + " not found");
|
||||
}
|
||||
|
||||
private static void compile(int rc, String... args) throws Exception {
|
||||
System.err.println("compile: " + Arrays.asList(args));
|
||||
StringWriter sw = new StringWriter();
|
||||
PrintWriter pw = new PrintWriter(sw);
|
||||
int rc2 = com.sun.tools.javac.Main.compile(args, pw);
|
||||
pw.close();
|
||||
System.err.println(sw);
|
||||
if (rc != rc2)
|
||||
throw new Exception("bad exit code; expected " + rc + ", found " + rc2);
|
||||
}
|
||||
}
|
@ -1,4 +1,6 @@
|
||||
DeprecatedDocComment.java:27:28: compiler.warn.has.been.deprecated: deprecatedTest1(), DeprecatedDocComment2
|
||||
DeprecatedDocComment.java:31:28: compiler.warn.has.been.deprecated: deprecatedTest5(), DeprecatedDocComment2
|
||||
DeprecatedDocComment.java:32:28: compiler.warn.has.been.deprecated: deprecatedTest6(), DeprecatedDocComment2
|
||||
- compiler.err.warnings.and.werror
|
||||
1 error
|
||||
3 warnings
|
||||
|
Loading…
Reference in New Issue
Block a user