From 33587ffd35c568c1ef034f064e6f3f06fe9943c3 Mon Sep 17 00:00:00 2001 From: Bo Zhang Date: Tue, 29 Nov 2022 13:57:56 +0000 Subject: [PATCH] 8292625: jshell crash on "var a = a" Reviewed-by: jlaskey, jlahoda --- .../com/sun/tools/javac/comp/Attr.java | 2 +- test/langtools/jdk/jshell/ToolSimpleTest.java | 13 +++- .../tools/javac/attr/AttrRecoveryTest.java | 60 +++++++++++++++++++ 3 files changed, 73 insertions(+), 2 deletions(-) diff --git a/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Attr.java b/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Attr.java index fb2706e2ab9..7e73fffc317 100644 --- a/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Attr.java +++ b/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Attr.java @@ -4653,7 +4653,7 @@ public class Attr extends JCTree.Visitor { && v.type.hasTag(NONE)) { //self reference to implicitly typed variable declaration log.error(TreeInfo.positionFor(v, env.enclClass), Errors.CantInferLocalVarType(v.name, Fragments.LocalSelfRef)); - return v.type = types.createErrorType(v.type); + return tree.type = v.type = types.createErrorType(v.type); } // Test (4): if symbol is an instance field of a raw type, diff --git a/test/langtools/jdk/jshell/ToolSimpleTest.java b/test/langtools/jdk/jshell/ToolSimpleTest.java index 6994e3b99f2..052e55991de 100644 --- a/test/langtools/jdk/jshell/ToolSimpleTest.java +++ b/test/langtools/jdk/jshell/ToolSimpleTest.java @@ -23,7 +23,11 @@ /* * @test - * @bug 8153716 8143955 8151754 8150382 8153920 8156910 8131024 8160089 8153897 8167128 8154513 8170015 8170368 8172102 8172103 8165405 8173073 8173848 8174041 8173916 8174028 8174262 8174797 8177079 8180508 8177466 8172154 8192979 8191842 8198573 8198801 8210596 8210959 8215099 8199623 8236715 8239536 8247456 8246774 8238173 + * @bug 8153716 8143955 8151754 8150382 8153920 8156910 8131024 8160089 8153897 + * 8167128 8154513 8170015 8170368 8172102 8172103 8165405 8173073 8173848 + * 8174041 8173916 8174028 8174262 8174797 8177079 8180508 8177466 8172154 + * 8192979 8191842 8198573 8198801 8210596 8210959 8215099 8199623 8236715 + * 8239536 8247456 8246774 8238173 8292625 * @summary Simple jshell tool tests * @modules jdk.compiler/com.sun.tools.javac.api * jdk.compiler/com.sun.tools.javac.main @@ -957,4 +961,11 @@ public class ToolSimpleTest extends ReplToolTesting { (a) -> assertCommand(a, "i", "i ==> 1") ); } + + @Test + public void testSelfReference() { + test( + (a) -> assertCommandOutputContains(a, "var a = a;", "cannot use 'var' on self-referencing variable") + ); + } } diff --git a/test/langtools/tools/javac/attr/AttrRecoveryTest.java b/test/langtools/tools/javac/attr/AttrRecoveryTest.java index b364cc28001..f5589a8093f 100644 --- a/test/langtools/tools/javac/attr/AttrRecoveryTest.java +++ b/test/langtools/tools/javac/attr/AttrRecoveryTest.java @@ -36,6 +36,7 @@ import com.sun.source.tree.AnnotationTree; import com.sun.source.tree.CompilationUnitTree; import com.sun.source.tree.ErroneousTree; +import com.sun.source.tree.VariableTree; import com.sun.source.util.TaskEvent; import com.sun.source.util.TaskListener; import com.sun.source.util.TreePath; @@ -45,7 +46,9 @@ import java.nio.file.Files; import java.nio.file.Path; import java.nio.file.Paths; import java.util.List; +import java.util.concurrent.atomic.AtomicInteger; import javax.lang.model.element.Element; +import javax.lang.model.type.TypeMirror; import toolbox.TestRunner; import toolbox.JavacTask; @@ -162,4 +165,61 @@ public class AttrRecoveryTest extends TestRunner { throw new AssertionError(); } } + + @Test + public void testVarAssignment2Self(Path base) throws Exception { + Path current = base; + Path src = current.resolve("src"); + Path classes = current.resolve("classes"); + tb.writeJavaFiles(src, + """ + public class Test { + void t() { + var v = v; + } + } + """); + + Files.createDirectories(classes); + + AtomicInteger seenVariables = new AtomicInteger(); + TreePathScanner checkTypes = new TreePathScanner<>() { + @Override + public Void visitVariable(VariableTree node, Trees trees) { + if (node.getName().contentEquals("v")) { + TypeMirror type = trees.getTypeMirror(getCurrentPath()); + if (type == null) { + throw new AssertionError("Unexpected null type!"); + } + seenVariables.incrementAndGet(); + } + return super.visitVariable(node, trees); + } + }; + + new JavacTask(tb) + .options("-XDrawDiagnostics") + .outdir(classes) + .files(tb.findJavaFiles(src)) + .callback(t -> { + t.addTaskListener(new TaskListener() { + CompilationUnitTree parsed; + @Override + public void finished(TaskEvent e) { + switch (e.getKind()) { + case PARSE -> parsed = e.getCompilationUnit(); + case COMPILATION -> + checkTypes.scan(parsed, Trees.instance(t)); + } + } + }); + }) + .run(Task.Expect.FAIL) + .writeAll() + .getOutputLines(Task.OutputKind.DIRECT); + + if (seenVariables.get() != 1) { + throw new AssertionError("Didn't see enough variables: " + seenVariables); + } + } }