From d07b9fdfdea07b1d5fcfd27a67e635d42684bae9 Mon Sep 17 00:00:00 2001 From: Robert Field Date: Sun, 25 Jun 2017 13:42:31 -0700 Subject: [PATCH] 8176110: JShell: completions with package results should, in most cases, be dot terminated Reviewed-by: jlahoda --- .../jdk/jshell/SourceCodeAnalysisImpl.java | 12 ++++++-- .../jdk/jshell/CompletionSuggestionTest.java | 28 +++++++++---------- 2 files changed, 24 insertions(+), 16 deletions(-) diff --git a/langtools/src/jdk.jshell/share/classes/jdk/jshell/SourceCodeAnalysisImpl.java b/langtools/src/jdk.jshell/share/classes/jdk/jshell/SourceCodeAnalysisImpl.java index fccf5cedce6..a1095e2bd32 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/jshell/SourceCodeAnalysisImpl.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/jshell/SourceCodeAnalysisImpl.java @@ -673,8 +673,16 @@ class SourceCodeAnalysisImpl extends SourceCodeAnalysis { continue; } String simpleName = simpleName(c); - if (c.getKind() == ElementKind.CONSTRUCTOR || c.getKind() == ElementKind.METHOD) { - simpleName += paren.apply(hasParams.contains(simpleName)); + switch (c.getKind()) { + case CONSTRUCTOR: + case METHOD: + // add trailing open or matched parenthesis, as approriate + simpleName += paren.apply(hasParams.contains(simpleName)); + break; + case PACKAGE: + // add trailing dot to package names + simpleName += "."; + break; } result.add(new SuggestionImpl(simpleName, smart.test(c))); } diff --git a/langtools/test/jdk/jshell/CompletionSuggestionTest.java b/langtools/test/jdk/jshell/CompletionSuggestionTest.java index 8ec12c05fd5..402fb92cd0f 100644 --- a/langtools/test/jdk/jshell/CompletionSuggestionTest.java +++ b/langtools/test/jdk/jshell/CompletionSuggestionTest.java @@ -23,7 +23,7 @@ /* * @test - * @bug 8131025 8141092 8153761 8145263 8131019 8175886 8176184 8176241 + * @bug 8131025 8141092 8153761 8145263 8131019 8175886 8176184 8176241 8176110 * @summary Test Completion and Documentation * @library /tools/lib * @modules jdk.compiler/com.sun.tools.javac.api @@ -180,7 +180,7 @@ public class CompletionSuggestionTest extends KullaTesting { assertCompletion("list.add(0, |", true, "ccTest3"); assertCompletion("new String(|", true, "ccTest3"); assertCompletion("new String(new char[0], |", true, "ccTest1", "ccTest2"); - assertCompletionIncludesExcludes("new jav|", new HashSet<>(Arrays.asList("java", "javax")), Collections.emptySet()); + assertCompletionIncludesExcludes("new jav|", new HashSet<>(Arrays.asList("java.", "javax.")), Collections.emptySet()); assertCompletion("Class clazz = String.c|", true, "class"); Snippet klass = classKey(assertEval("class Klass {void method(int n) {} private void method(String str) {}}")); @@ -241,14 +241,14 @@ public class CompletionSuggestionTest extends KullaTesting { } public void testFullyQualified() { - assertCompletion("Optional opt = java.u|", "util"); + assertCompletion("Optional opt = java.u|", "util."); assertCompletionIncludesExcludes("Optional opt = java.util.O|", new HashSet<>(Collections.singletonList("Optional")), Collections.emptySet()); assertEval("void method(java.util.Optional opt) {}"); - assertCompletion("method(java.u|", "util"); + assertCompletion("method(java.u|", "util."); assertCompletion("Object.notElement.|"); - assertCompletion("Object o = com.su|", "sun"); + assertCompletion("Object o = com.su|", "sun."); Path p1 = outDir.resolve("dir1"); compiler.compile(p1, @@ -262,8 +262,8 @@ public class CompletionSuggestionTest extends KullaTesting { compiler.jar(p1, jarName, "p1/p2/Test.class", "p1/p3/Test.class"); addToClasspath(compiler.getPath(p1.resolve(jarName))); - assertCompletionIncludesExcludes("|", new HashSet<>(Collections.singletonList("p1")), Collections.emptySet()); - assertCompletion("p1.|", "p2", "p3"); + assertCompletionIncludesExcludes("|", new HashSet<>(Collections.singletonList("p1.")), Collections.emptySet()); + assertCompletion("p1.|", "p2.", "p3."); assertCompletion("p1.p2.|", "Test"); assertCompletion("p1.p3.|", "Test"); } @@ -273,15 +273,15 @@ public class CompletionSuggestionTest extends KullaTesting { } public void testCompletePackages() { - assertCompletion("java.u|", "util"); - assertCompletionIncludesExcludes("jav|", new HashSet<>(Arrays.asList("java", "javax")), Collections.emptySet()); + assertCompletion("java.u|", "util."); + assertCompletionIncludesExcludes("jav|", new HashSet<>(Arrays.asList("java.", "javax.")), Collections.emptySet()); } public void testImports() { - assertCompletion("import java.u|", "util"); - assertCompletionIncludesExcludes("import jav|", new HashSet<>(Arrays.asList("java", "javax")), Collections.emptySet()); - assertCompletion("import static java.u|", "util"); - assertCompletionIncludesExcludes("import static jav|", new HashSet<>(Arrays.asList("java", "javax")), Collections.emptySet()); + assertCompletion("import java.u|", "util."); + assertCompletionIncludesExcludes("import jav|", new HashSet<>(Arrays.asList("java.", "javax.")), Collections.emptySet()); + assertCompletion("import static java.u|", "util."); + assertCompletionIncludesExcludes("import static jav|", new HashSet<>(Arrays.asList("java.", "javax.")), Collections.emptySet()); assertCompletion("import static java.lang.Boolean.g|", "getBoolean"); assertCompletion("import java.util.*|"); assertCompletionIncludesExcludes("import java.lang.String.|", @@ -296,7 +296,7 @@ public class CompletionSuggestionTest extends KullaTesting { } public void testImportStart() { - assertCompletionIncludesExcludes("import c|", Set.of("com"), Set.of()); + assertCompletionIncludesExcludes("import c|", Set.of("com."), Set.of()); } public void testBrokenClassFile() throws Exception {