From 7dc011cccac59eeb91a49aec58886641988f225a Mon Sep 17 00:00:00 2001 From: Bernard Blaser Date: Wed, 2 May 2018 15:29:55 +0100 Subject: [PATCH] 8202372: Diagnostic with incorrect line info generated when compiling lambda expression Add tree position to speculative lambda tree Reviewed-by: vromero, jlahoda --- .../sun/tools/javac/comp/DeferredAttr.java | 2 +- .../tools/javac/lambda/8202372/T8202372.java | 45 +++++++++++++++++++ .../tools/javac/lambda/8202372/T8202372.out | 8 ++++ test/langtools/tools/javac/lvti/T8200199.java | 2 +- .../badTypeReference/BadTypeReference.java | 2 +- .../javac/preview/classReaderTest/Client.java | 2 +- 6 files changed, 57 insertions(+), 4 deletions(-) create mode 100644 test/langtools/tools/javac/lambda/8202372/T8202372.java create mode 100644 test/langtools/tools/javac/lambda/8202372/T8202372.out diff --git a/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/DeferredAttr.java b/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/DeferredAttr.java index c3a3964d1d8..1b74e1f7f11 100644 --- a/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/DeferredAttr.java +++ b/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/DeferredAttr.java @@ -441,7 +441,7 @@ public class DeferredAttr extends JCTree.Visitor { } else { stats.add((JCBlock)that.body); } - JCBlock lambdaBlock = make.Block(0, stats.toList()); + JCBlock lambdaBlock = make.at(that.pos).Block(0, stats.toList()); Env localEnv = attr.lambdaEnv(that, env); try { localEnv.info.returnResult = resultInfo; diff --git a/test/langtools/tools/javac/lambda/8202372/T8202372.java b/test/langtools/tools/javac/lambda/8202372/T8202372.java new file mode 100644 index 00000000000..18d971a4d61 --- /dev/null +++ b/test/langtools/tools/javac/lambda/8202372/T8202372.java @@ -0,0 +1,45 @@ +/* + * @test /nodynamiccopyright/ + * @bug 8202372 + * @summary Diagnostic with incorrect line info generated when compiling lambda expression + * @compile/fail/ref=T8202372.out -XDrawDiagnostics T8202372.java + */ +class T8202372 { + + interface NonVoidFunc { + String m(); + } + + interface VoidFunc { + void m(); + } + + interface ParamFunc { + void m(String s); + } + + public void addVoid(VoidFunc v) {} + public void addNonVoid(NonVoidFunc nv) {} + public void addParam(ParamFunc p) {} + + void testVoid(T8202372 test) { + test.addVoid(() -> ""); + test.addVoid(() -> { return ""; }); + test.addVoid(() -> { }); + test.addVoid(() -> { return; }); + } + + void testNonVoid(T8202372 test) { + test.addNonVoid(() -> ""); + test.addNonVoid(() -> { return ""; }); + test.addNonVoid(() -> { }); + test.addNonVoid(() -> { return; }); + } + + void testParam(T8202372 test) { + test.addParam(() -> {}); + test.addParam((String x) -> { }); + test.addParam((String x1, String x2) -> { }); + test.addParam((int x) -> { }); + } +} \ No newline at end of file diff --git a/test/langtools/tools/javac/lambda/8202372/T8202372.out b/test/langtools/tools/javac/lambda/8202372/T8202372.out new file mode 100644 index 00000000000..368fe8bd808 --- /dev/null +++ b/test/langtools/tools/javac/lambda/8202372/T8202372.out @@ -0,0 +1,8 @@ +T8202372.java:26:13: compiler.err.cant.apply.symbol: kindname.method, addVoid, T8202372.VoidFunc, @22, kindname.class, T8202372, (compiler.misc.no.conforming.assignment.exists: (compiler.misc.stat.expr.expected)) +T8202372.java:27:13: compiler.err.cant.apply.symbol: kindname.method, addVoid, T8202372.VoidFunc, @22, kindname.class, T8202372, (compiler.misc.no.conforming.assignment.exists: (compiler.misc.incompatible.ret.type.in.lambda: (compiler.misc.unexpected.ret.val))) +T8202372.java:35:13: compiler.err.cant.apply.symbol: kindname.method, addNonVoid, T8202372.NonVoidFunc, @25, kindname.class, T8202372, (compiler.misc.no.conforming.assignment.exists: (compiler.misc.incompatible.ret.type.in.lambda: (compiler.misc.missing.ret.val: java.lang.String))) +T8202372.java:36:13: compiler.err.cant.apply.symbol: kindname.method, addNonVoid, T8202372.NonVoidFunc, @25, kindname.class, T8202372, (compiler.misc.no.conforming.assignment.exists: (compiler.misc.incompatible.ret.type.in.lambda: (compiler.misc.missing.ret.val))) +T8202372.java:40:13: compiler.err.cant.apply.symbol: kindname.method, addParam, T8202372.ParamFunc, @23, kindname.class, T8202372, (compiler.misc.no.conforming.assignment.exists: (compiler.misc.incompatible.arg.types.in.lambda)) +T8202372.java:42:13: compiler.err.cant.apply.symbol: kindname.method, addParam, T8202372.ParamFunc, @23, kindname.class, T8202372, (compiler.misc.no.conforming.assignment.exists: (compiler.misc.incompatible.arg.types.in.lambda)) +T8202372.java:43:13: compiler.err.cant.apply.symbol: kindname.method, addParam, T8202372.ParamFunc, @23, kindname.class, T8202372, (compiler.misc.no.conforming.assignment.exists: (compiler.misc.incompatible.arg.types.in.lambda)) +7 errors diff --git a/test/langtools/tools/javac/lvti/T8200199.java b/test/langtools/tools/javac/lvti/T8200199.java index 60bcdfea20f..259ef81fa15 100644 --- a/test/langtools/tools/javac/lvti/T8200199.java +++ b/test/langtools/tools/javac/lvti/T8200199.java @@ -24,7 +24,7 @@ */ /* - * @test /nodynamioccopyright/ + * @test /nodynamiccopyright/ * @bug 8200199 * @summary javac suggests to use var even when var is used * @compile/fail/ref=T8200199.out -Werror -XDfind=local -XDrawDiagnostics T8200199.java diff --git a/test/langtools/tools/javac/lvti/badTypeReference/BadTypeReference.java b/test/langtools/tools/javac/lvti/badTypeReference/BadTypeReference.java index 0dfe7b6f08b..8bfe7c37725 100644 --- a/test/langtools/tools/javac/lvti/badTypeReference/BadTypeReference.java +++ b/test/langtools/tools/javac/lvti/badTypeReference/BadTypeReference.java @@ -24,7 +24,7 @@ */ /* - * @test /nodynamioccopyright/ + * @test /nodynamiccopyright/ * @bug 8177466 * @summary Add compiler support for local variable type-inference * @compile -source 8 pkg/var.java diff --git a/test/langtools/tools/javac/preview/classReaderTest/Client.java b/test/langtools/tools/javac/preview/classReaderTest/Client.java index 91ac53e334e..cf9d6e22f16 100644 --- a/test/langtools/tools/javac/preview/classReaderTest/Client.java +++ b/test/langtools/tools/javac/preview/classReaderTest/Client.java @@ -1,5 +1,5 @@ /* - * @test /nodynamioccopyright/ + * @test /nodynamiccopyright/ * @bug 8199194 * @summary smoke test for --enabled-preview classreader support * @compile -XDforcePreview --enable-preview -source 11 Bar.java