summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGeorge Fraser <george@fivetran.com>2018-12-31 15:09:44 -0800
committerGeorge Fraser <george@fivetran.com>2018-12-31 15:09:44 -0800
commit8f63f14f980f44af2c5747747320703819ebc402 (patch)
treef8663c3592f195f59eb944452fb26ffec88a0570
parent802686046fe1ae412fa3fc559488db5b644db499 (diff)
downloadjava-language-server-8f63f14f980f44af2c5747747320703819ebc402.zip
Simplify
-rw-r--r--TODOS.md4
-rw-r--r--src/main/java/org/javacs/CompileFile.java21
-rw-r--r--src/main/java/org/javacs/FixImports.java17
-rw-r--r--src/main/java/org/javacs/JavaLanguageServer.java47
-rw-r--r--src/test/java/org/javacs/JavaCompilerServiceTest.java2
5 files changed, 39 insertions, 52 deletions
diff --git a/TODOS.md b/TODOS.md
index 4c27556..9a620b3 100644
--- a/TODOS.md
+++ b/TODOS.md
@@ -18,15 +18,11 @@
- Go-to-implementation for overridden methods
## Polish
-- Hover constructor should show constructor, not class
- Show warning for unused local var, unused private method
- Use cached codelens during parse errors to prevent things from jumping around, or codelens-on-save
- Suppress references codelens for inherited methods
- Don't remove imports when there's an unresolved reference to that name
-## Simplicity
-- Use module-info.java instead of build files to figure out classpath
-
## JShell
- Support .jshell extension as "scratch pad"
diff --git a/src/main/java/org/javacs/CompileFile.java b/src/main/java/org/javacs/CompileFile.java
index 7b8a9f0..c26337d 100644
--- a/src/main/java/org/javacs/CompileFile.java
+++ b/src/main/java/org/javacs/CompileFile.java
@@ -8,7 +8,10 @@ import java.net.URI;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
+import java.util.ArrayList;
+import java.util.Collections;
import java.util.HashSet;
+import java.util.List;
import java.util.Objects;
import java.util.Optional;
import java.util.logging.Logger;
@@ -18,11 +21,11 @@ import org.javacs.lsp.*;
public class CompileFile {
private final JavaCompilerService parent;
- final URI file;
- final String contents;
+ public final URI file;
+ public final String contents;
private final JavacTask task;
private final Trees trees;
- private final CompilationUnitTree root;
+ public final CompilationUnitTree root;
CompileFile(JavaCompilerService parent, URI file, String contents) {
this.parent = parent;
@@ -44,6 +47,10 @@ public class CompileFile {
profiler.print();
}
+ public SourcePositions sourcePositions() {
+ return trees.getSourcePositions();
+ }
+
public Optional<Element> element(int line, int character) {
LOG.info(String.format("Looking for element under cursor %s(%d,%d)...", file, line, character));
@@ -119,7 +126,7 @@ public class CompileFile {
* Figure out what imports this file should have. Star-imports like `import java.util.*` are converted to individual
* class imports. Missing imports are inferred by looking at imports in other source files.
*/
- public FixImports fixImports() {
+ public List<String> fixImports() {
// Check diagnostics for missing imports
var unresolved = new HashSet<String>();
for (var d : parent.diags) {
@@ -181,7 +188,11 @@ public class CompileFile {
}
// Add qualified names from fixes
qualifiedNames.addAll(fixes.values());
- return new FixImports(root, trees.getSourcePositions(), qualifiedNames);
+ // Sort in alphabetical order
+ var sorted = new ArrayList<String>();
+ sorted.addAll(qualifiedNames);
+ Collections.sort(sorted);
+ return sorted;
}
public Optional<URI> declaringFile(Element e) {
diff --git a/src/main/java/org/javacs/FixImports.java b/src/main/java/org/javacs/FixImports.java
deleted file mode 100644
index 751c756..0000000
--- a/src/main/java/org/javacs/FixImports.java
+++ /dev/null
@@ -1,17 +0,0 @@
-package org.javacs;
-
-import com.sun.source.tree.CompilationUnitTree;
-import com.sun.source.util.SourcePositions;
-import java.util.Set;
-
-class FixImports {
- final CompilationUnitTree parsed;
- final SourcePositions sourcePositions;
- final Set<String> fixedImports;
-
- FixImports(CompilationUnitTree parsed, SourcePositions sourcePositions, Set<String> fixedImports) {
- this.parsed = parsed;
- this.sourcePositions = sourcePositions;
- this.fixedImports = fixedImports;
- }
-}
diff --git a/src/main/java/org/javacs/JavaLanguageServer.java b/src/main/java/org/javacs/JavaLanguageServer.java
index 4048919..30b869a 100644
--- a/src/main/java/org/javacs/JavaLanguageServer.java
+++ b/src/main/java/org/javacs/JavaLanguageServer.java
@@ -586,8 +586,10 @@ class JavaLanguageServer extends LanguageServer {
} else return Optional.empty();
}
+ // TODO change name
private CompileFile hoverCache;
+ // TODO take only URI and invalidate based on version
private void updateHoverCache(URI uri, String contents) {
if (hoverCache == null || !hoverCache.file.equals(uri) || !hoverCache.contents.equals(contents)) {
LOG.info("File has changed since last hover, recompiling");
@@ -1011,36 +1013,39 @@ class JavaLanguageServer extends LanguageServer {
return unresolved;
}
- private List<TextEdit> fixImports(URI java) {
- var contents = contents(java).content;
- var fix = compiler.compileFile(java, contents).fixImports();
+ @Override
+ public List<TextEdit> formatting(DocumentFormattingParams params) {
+ updateHoverCache(params.textDocument.uri, contents(params.textDocument.uri).content);
// TODO if imports already match fixed-imports, return empty list
// TODO preserve comments and other details of existing imports
+ var imports = hoverCache.fixImports();
+ var pos = hoverCache.sourcePositions();
+ var lines = hoverCache.root.getLineMap();
var edits = new ArrayList<TextEdit>();
// Delete all existing imports
- for (var i : fix.parsed.getImports()) {
+ for (var i : hoverCache.root.getImports()) {
if (!i.isStatic()) {
- var offset = fix.sourcePositions.getStartPosition(fix.parsed, i);
- var line = (int) fix.parsed.getLineMap().getLineNumber(offset) - 1;
+ var offset = pos.getStartPosition(hoverCache.root, i);
+ var line = (int) lines.getLineNumber(offset) - 1;
var delete = new TextEdit(new Range(new Position(line, 0), new Position(line + 1, 0)), "");
edits.add(delete);
}
}
- if (fix.fixedImports.isEmpty()) return edits;
+ if (imports.isEmpty()) return edits;
// Find a place to insert the new imports
long insertLine = -1;
var insertText = new StringBuilder();
// If there are imports, use the start of the first import as the insert position
- for (var i : fix.parsed.getImports()) {
+ for (var i : hoverCache.root.getImports()) {
if (!i.isStatic() && insertLine == -1) {
- long offset = fix.sourcePositions.getStartPosition(fix.parsed, i);
- insertLine = fix.parsed.getLineMap().getLineNumber(offset) - 1;
+ long offset = pos.getStartPosition(hoverCache.root, i);
+ insertLine = lines.getLineNumber(offset) - 1;
}
}
// If there are no imports, insert after the package declaration
- if (insertLine == -1 && fix.parsed.getPackageName() != null) {
- long offset = fix.sourcePositions.getEndPosition(fix.parsed, fix.parsed.getPackageName());
- insertLine = fix.parsed.getLineMap().getLineNumber(offset);
+ if (insertLine == -1 && hoverCache.root.getPackageName() != null) {
+ long offset = pos.getEndPosition(hoverCache.root, hoverCache.root.getPackageName());
+ insertLine = lines.getLineNumber(offset);
insertText.append("\n");
}
// If there are no imports and no package, insert at the top of the file
@@ -1048,22 +1053,14 @@ class JavaLanguageServer extends LanguageServer {
insertLine = 0;
}
// Insert each import
- fix.fixedImports
- .stream()
- .sorted()
- .forEach(
- i -> {
- insertText.append("import ").append(i).append(";\n");
- });
+ for (var i : imports) {
+ insertText.append("import ").append(i).append(";\n");
+ }
var insertPosition = new Position((int) insertLine, 0);
var insert = new TextEdit(new Range(insertPosition, insertPosition), insertText.toString());
edits.add(insert);
- return edits;
- }
- @Override
- public List<TextEdit> formatting(DocumentFormattingParams params) {
- return fixImports(params.textDocument.uri);
+ return edits;
}
@Override
diff --git a/src/test/java/org/javacs/JavaCompilerServiceTest.java b/src/test/java/org/javacs/JavaCompilerServiceTest.java
index b0f80e1..69d032b 100644
--- a/src/test/java/org/javacs/JavaCompilerServiceTest.java
+++ b/src/test/java/org/javacs/JavaCompilerServiceTest.java
@@ -312,7 +312,7 @@ public class JavaCompilerServiceTest {
public void fixImports() {
var uri = resourceUri("MissingImport.java");
var contents = contents("MissingImport.java");
- var qualifiedNames = compiler.compileFile(uri, contents).fixImports().fixedImports;
+ var qualifiedNames = compiler.compileFile(uri, contents).fixImports();
assertThat(qualifiedNames, hasItem("java.util.List"));
}