8187591: -Werror turns incubator module warning to an error

Reviewed-by: jlahoda
This commit is contained in:
Adam Sotona 2023-11-21 15:11:00 +00:00
parent 570dffb104
commit 53eb6f126b
6 changed files with 34 additions and 7 deletions

View File

@ -130,6 +130,7 @@ public class Lint
values.add(LintCategory.PREVIEW);
}
values.add(LintCategory.SYNCHRONIZATION);
values.add(LintCategory.INCUBATING);
}
// Look for specific overrides
@ -215,6 +216,11 @@ public class Lint
*/
FINALLY("finally"),
/**
* Warn about use of incubating modules.
*/
INCUBATING("incubating"),
/**
* Warn about compiler possible lossy conversions.
*/

View File

@ -117,6 +117,7 @@ import com.sun.tools.javac.code.Kinds;
import static com.sun.tools.javac.code.Kinds.Kind.ERR;
import static com.sun.tools.javac.code.Kinds.Kind.MDL;
import static com.sun.tools.javac.code.Kinds.Kind.MTH;
import com.sun.tools.javac.code.Lint;
import com.sun.tools.javac.code.Symbol.ModuleResolutionFlags;
@ -134,6 +135,7 @@ public class Modules extends JCTree.Visitor {
private static final String ALL_SYSTEM = "ALL-SYSTEM";
private static final String ALL_MODULE_PATH = "ALL-MODULE-PATH";
private final Lint lint;
private final Log log;
private final Names names;
private final Symtab syms;
@ -185,6 +187,7 @@ public class Modules extends JCTree.Visitor {
protected Modules(Context context) {
context.put(Modules.class, this);
log = Log.instance(context);
lint = Lint.instance(context);
names = Names.instance(context);
syms = Symtab.instance(context);
attr = Attr.instance(context);
@ -1351,6 +1354,7 @@ public class Modules extends JCTree.Visitor {
.forEach(result::add);
}
if (lint.isEnabled(LintCategory.INCUBATING)) {
String incubatingModules = filterAlreadyWarnedIncubatorModules(result.stream()
.filter(msym -> msym.resolutionFlags.contains(ModuleResolutionFlags.WARN_INCUBATING))
.map(msym -> msym.name.toString()))
@ -1359,6 +1363,7 @@ public class Modules extends JCTree.Visitor {
if (!incubatingModules.isEmpty()) {
log.warning(Warnings.IncubatingModules(incubatingModules));
}
}
allModules = result;

View File

@ -213,6 +213,9 @@ javac.opt.Xlint.desc.fallthrough=\
javac.opt.Xlint.desc.finally=\
Warn about finally clauses that do not terminate normally.
javac.opt.Xlint.desc.incubating=\
Warn about use of incubating modules.
javac.opt.Xlint.desc.lossy-conversions=\
Warn about possible lossy conversions in compound assignment.

View File

@ -162,6 +162,7 @@ import javax.tools.StandardLocation;
* <tr><th scope="row">{@code fallthrough} <td>falling through from one case of a {@code switch} statement to
* the next
* <tr><th scope="row">{@code finally} <td>{@code finally} clauses that do not terminate normally
* <tr><th scope="row">{@code incubating} <td>use of incubating modules
* <tr><th scope="row">{@code lossy-conversions} <td>possible lossy conversions in compound assignment
* <tr><th scope="row">{@code missing-explicit-ctor} <td>missing explicit constructors in public and protected classes
* in exported packages

View File

@ -725,6 +725,8 @@ a switch statement to the next.
\f[V]finally\f[R]: Warns about \f[V]finally\f[R] clauses that do not
terminate normally.
.IP \[bu] 2
\f[V]incubating\f[R]: Warns about the use of incubating modules.
.IP \[bu] 2
\f[V]lossy-conversions\f[R]: Warns about possible lossy conversions in
compound assignment.
.IP \[bu] 2

View File

@ -23,7 +23,7 @@
/*
* @test
* @bug 8171177
* @bug 8171177 8187591
* @summary Verify that ModuleResolution attribute flags are honored.
* @library /tools/lib
* @modules jdk.compiler/com.sun.tools.javac.api
@ -238,6 +238,16 @@ public class IncubatingTest extends ModuleTestBase {
if (!expected.equals(log)) {
throw new AssertionError("Unexpected output: " + log);
}
//test disable lint incubating
new JavacTask(tb)
.options("--module-path", classes.toString(),
"-XDrawDiagnostics",
"-Xlint:-incubating",
"-Werror")
.outdir(testModuleClasses)
.files(findJavaFiles(testModuleSrc))
.run(Expect.SUCCESS);
}
private void copyJavaBase(Path targetDir) throws IOException {