summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorGeorge Fraser <george@fivetran.com>2019-01-05 21:55:16 -0800
committerGeorge Fraser <george@fivetran.com>2019-01-05 21:55:16 -0800
commitc4ad50a74ac99ea48424be120d1c369b9f1d24e0 (patch)
treea6a430aa05f1d9aca33c31db73c29e5d76abc6f0 /src
parent69ee31525a2be65254aafec0b5bf2d959e1a9b84 (diff)
downloadjava-language-server-c4ad50a74ac99ea48424be120d1c369b9f1d24e0.zip
Minor fixes
Diffstat (limited to 'src')
-rw-r--r--src/main/java/org/javacs/CompileBatch.java1
-rw-r--r--src/main/java/org/javacs/JavaCompilerService.java2
-rw-r--r--src/main/java/org/javacs/JavaLanguageServer.java6
-rw-r--r--src/main/java/org/javacs/lsp/Diagnostic.java3
4 files changed, 10 insertions, 2 deletions
diff --git a/src/main/java/org/javacs/CompileBatch.java b/src/main/java/org/javacs/CompileBatch.java
index fdb2da4..6b94b73 100644
--- a/src/main/java/org/javacs/CompileBatch.java
+++ b/src/main/java/org/javacs/CompileBatch.java
@@ -246,6 +246,7 @@ public class CompileBatch {
for (var r : roots) {
finder.scan(r, null);
}
+ LOG.info(String.format("...found %d references", refs.size()));
return refs;
}
diff --git a/src/main/java/org/javacs/JavaCompilerService.java b/src/main/java/org/javacs/JavaCompilerService.java
index 68695e7..5cfb418 100644
--- a/src/main/java/org/javacs/JavaCompilerService.java
+++ b/src/main/java/org/javacs/JavaCompilerService.java
@@ -319,7 +319,7 @@ public class JavaCompilerService {
return scanForPotentialReferences(to, new FindMethod());
} else {
// Fields, type parameters can only be referenced from within the same file
- LOG.info(String.format("...find definition of `%s`", to));
+ LOG.info(String.format("...references to `%s` must be in the same file", to));
var files = new HashSet<URI>();
var toFile = declaringFile(to);
// If there is no declaring file
diff --git a/src/main/java/org/javacs/JavaLanguageServer.java b/src/main/java/org/javacs/JavaLanguageServer.java
index af8ba41..86fb7cc 100644
--- a/src/main/java/org/javacs/JavaLanguageServer.java
+++ b/src/main/java/org/javacs/JavaLanguageServer.java
@@ -110,6 +110,9 @@ class JavaLanguageServer extends LanguageServer {
d.range = new Range(start, end);
d.code = j.getCode();
d.message = j.getMessage(null);
+ if (j.getCode().equals("unused")) {
+ d.tags = List.of(DiagnosticTag.Unnecessary);
+ }
// Add to byUri
var ds = byUri.computeIfAbsent(uri, __ -> new ArrayList<>());
ds.add(d);
@@ -341,6 +344,7 @@ class JavaLanguageServer extends LanguageServer {
@Override
public Optional<CompletionList> completion(TextDocumentPositionParams position) {
+ // TODO reuse previous compilation when changes are small
var started = Instant.now();
var uri = position.textDocument.uri;
if (!isJavaFile(uri)) return Optional.empty();
@@ -1019,7 +1023,7 @@ class JavaLanguageServer extends LanguageServer {
String title;
if (count == -1) title = "? references";
else if (count == 1) title = "1 reference";
- else if (count == 100) title = "Many references";
+ else if (count == 100) title = "Find references";
else title = String.format("%d references", count);
var arguments = new JsonArray();
arguments.add(uri.toString());
diff --git a/src/main/java/org/javacs/lsp/Diagnostic.java b/src/main/java/org/javacs/lsp/Diagnostic.java
index 404957e..2cd4f09 100644
--- a/src/main/java/org/javacs/lsp/Diagnostic.java
+++ b/src/main/java/org/javacs/lsp/Diagnostic.java
@@ -1,7 +1,10 @@
package org.javacs.lsp;
+import java.util.List;
+
public class Diagnostic {
public Range range;
public Integer severity;
public String code, source, message;
+ public List<Integer> tags; // DiagnosticTag
}