diff options
author | George Fraser <george@fivetran.com> | 2018-09-21 23:51:01 -0700 |
---|---|---|
committer | George Fraser <george@fivetran.com> | 2018-09-21 23:51:01 -0700 |
commit | c856b581a05b35c063c4fedfba9a09aaab00bfc1 (patch) | |
tree | 3766280846af3035700cb875be3571f1398e2079 | |
parent | ee3968ce8b7af1a7f90b6a8fce20e702cd08158c (diff) | |
download | java-language-server-c856b581a05b35c063c4fedfba9a09aaab00bfc1.zip |
Complete implements
-rw-r--r-- | TODOS.md | 1 | ||||
-rw-r--r-- | src/main/java/org/javacs/JavaCompilerService.java | 32 | ||||
-rw-r--r-- | src/test/java/org/javacs/CompletionsTest.java | 8 | ||||
-rw-r--r-- | src/test/test-project/workspace/src/org/javacs/example/AutocompleteImplements.java | 3 |
4 files changed, 27 insertions, 17 deletions
@@ -6,7 +6,6 @@ ## Autocomplete - NameOfClass... default constructor initializing final fields -- im[plements] - Annotation fields - cc should match CamelCase diff --git a/src/main/java/org/javacs/JavaCompilerService.java b/src/main/java/org/javacs/JavaCompilerService.java index 5e2b721..743628b 100644 --- a/src/main/java/org/javacs/JavaCompilerService.java +++ b/src/main/java/org/javacs/JavaCompilerService.java @@ -619,6 +619,7 @@ public class JavaCompilerService { "abstract", "class", "interface", + "implements", }; private static String[] CLASS_BODY_KEYWORDS = { @@ -824,30 +825,26 @@ public class JavaCompilerService { completeScopeIdentifiers(partialName); // Add keywords if (insideClass == 0) { - for (var k : TOP_LEVEL_KEYWORDS) { - if (k.startsWith(partialName)) { - result.add(Completion.ofKeyword(k)); - } - } + addKeywords(TOP_LEVEL_KEYWORDS, partialName); } else if (insideMethod == 0) { - for (var k : CLASS_BODY_KEYWORDS) { - if (k.startsWith(partialName)) { - result.add(Completion.ofKeyword(k)); - } - } + addKeywords(CLASS_BODY_KEYWORDS, partialName); } else { - for (var k : METHOD_BODY_KEYWORDS) { - if (k.startsWith(partialName)) { - result.add(Completion.ofKeyword(k)); - } - } + addKeywords(METHOD_BODY_KEYWORDS, partialName); } } return null; } + private void addKeywords(String[] keywords, String partialName) { + for (var k : keywords) { + if (k.startsWith(partialName)) { + result.add(Completion.ofKeyword(k)); + } + } + } + private void completeScopeIdentifiers(String partialName) { var startsWithUpperCase = partialName.length() > 0 && Character.isUpperCase(partialName.charAt(0)); var alreadyImported = new HashSet<String>(); @@ -941,7 +938,10 @@ public class JavaCompilerService { CompletionResult run() { scan(parse, null); - if (result == null) result = Collections.emptyList(); + if (result == null) { + result = new ArrayList<>(); + addKeywords(TOP_LEVEL_KEYWORDS, ""); + } if (isIncomplete) LOG.info(String.format("Found %d items (incomplete)", result.size())); return new CompletionResult(result, isIncomplete); } diff --git a/src/test/java/org/javacs/CompletionsTest.java b/src/test/java/org/javacs/CompletionsTest.java index c8f01ca..12e7010 100644 --- a/src/test/java/org/javacs/CompletionsTest.java +++ b/src/test/java/org/javacs/CompletionsTest.java @@ -784,4 +784,12 @@ public class CompletionsTest extends CompletionsBase { assertThat(suggestions, hasItem(containsString("void superMethod() {"))); } + + @Test + public void implementsKeyword() { + var file = "/org/javacs/example/AutocompleteImplements.java"; + var suggestions = insertText(file, 3, 34); + + assertThat(suggestions, hasItem(containsString("implements"))); + } } diff --git a/src/test/test-project/workspace/src/org/javacs/example/AutocompleteImplements.java b/src/test/test-project/workspace/src/org/javacs/example/AutocompleteImplements.java new file mode 100644 index 0000000..9c8b2c0 --- /dev/null +++ b/src/test/test-project/workspace/src/org/javacs/example/AutocompleteImplements.java @@ -0,0 +1,3 @@ +package org.javacs.example; + +class AutocompleteImplements impl
\ No newline at end of file |