summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/main/java/org/javacs/CompileBatch.java54
-rw-r--r--src/test/java/org/javacs/GotoTest.java7
-rw-r--r--src/test/test-project/workspace/src/org/javacs/example/GotoError.java7
3 files changed, 61 insertions, 7 deletions
diff --git a/src/main/java/org/javacs/CompileBatch.java b/src/main/java/org/javacs/CompileBatch.java
index 78795fd..6d71e8e 100644
--- a/src/main/java/org/javacs/CompileBatch.java
+++ b/src/main/java/org/javacs/CompileBatch.java
@@ -11,6 +11,7 @@ import java.util.*;
import java.util.logging.Logger;
import java.util.stream.Collectors;
import javax.lang.model.element.*;
+import javax.lang.model.type.TypeKind;
import javax.lang.model.util.*;
import javax.tools.*;
import org.javacs.lsp.Range;
@@ -98,14 +99,24 @@ public class CompileBatch {
throw new RuntimeException("File " + uri + " isn't in batch " + roots);
}
- // TODO error is interpreted as object, which leads to "go-to-everywhere"
public List<TreePath> definitions(Element el) {
LOG.info(String.format("Search for definitions of `%s` in %d files...", el, roots.size()));
+ if (el.asType().getKind() == TypeKind.ERROR) {
+ LOG.info(String.format("...`%s` is an error type, giving up", el.asType()));
+ return List.of();
+ }
+
var refs = new ArrayList<TreePath>();
class FindDefinitions extends TreePathScanner<Void, Void> {
boolean sameSymbol(Element found) {
- return el.equals(found);
+ if (el.equals(found)) {
+ var uri = getCurrentPath().getCompilationUnit().getSourceFile().toUri();
+ var fileName = Parser.fileName(uri);
+ LOG.info(String.format("...%s is in %s", found, fileName));
+ return true;
+ }
+ return false;
}
boolean isSubMethod(Element found) {
@@ -114,7 +125,11 @@ public class CompileBatch {
var superMethod = (ExecutableElement) el;
var subMethod = (ExecutableElement) found;
var subType = (TypeElement) subMethod.getEnclosingElement();
- return elements.overrides(subMethod, superMethod, subType);
+ if (elements.overrides(subMethod, superMethod, subType)) {
+ LOG.info(String.format("...`%s.%s` overrides `%s`", subType, subMethod, superMethod));
+ return true;
+ }
+ return false;
}
boolean isSubType(Element found) {
@@ -122,7 +137,11 @@ public class CompileBatch {
if (!(found instanceof TypeElement)) return false;
var superType = (TypeElement) el;
var subType = (TypeElement) found;
- return types.isSubtype(subType.asType(), superType.asType());
+ if (types.isSubtype(subType.asType(), superType.asType())) {
+ LOG.info(String.format("...`%s` overrides `%s`", subType, superType));
+ return true;
+ }
+ return false;
}
void check(TreePath from) {
@@ -159,10 +178,21 @@ public class CompileBatch {
public List<TreePath> references(Element to) {
LOG.info(String.format("Search for references to `%s` in %d files...", to, roots.size()));
+ if (to.asType().getKind() == TypeKind.ERROR) {
+ LOG.info(String.format("...`%s` is an error type, giving up", to.asType()));
+ return List.of();
+ }
+
var refs = new ArrayList<TreePath>();
class FindReferences extends TreePathScanner<Void, Void> {
boolean sameSymbol(Element found) {
- return to.equals(found);
+ if (to.equals(found)) {
+ var uri = getCurrentPath().getCompilationUnit().getSourceFile().toUri();
+ var fileName = Parser.fileName(uri);
+ LOG.info(String.format("...%s is in %s", found, fileName));
+ return true;
+ }
+ return false;
}
boolean isSuperMethod(Element found) {
@@ -171,7 +201,11 @@ public class CompileBatch {
var subMethod = (ExecutableElement) to;
var subType = (TypeElement) subMethod.getEnclosingElement();
var superMethod = (ExecutableElement) found;
- return elements.overrides(subMethod, superMethod, subType);
+ if (elements.overrides(subMethod, superMethod, subType)) {
+ LOG.info(String.format("...`%s.%s` overrides `%s`", subType, subMethod, superMethod));
+ return true;
+ }
+ return false;
}
boolean isSuperType(Element found) {
@@ -179,7 +213,11 @@ public class CompileBatch {
if (!(found instanceof TypeElement)) return false;
var subType = (TypeElement) to;
var superType = (TypeElement) found;
- return types.isSubtype(subType.asType(), superType.asType());
+ if (types.isSubtype(subType.asType(), superType.asType())) {
+ LOG.info(String.format("...`%s` overrides `%s`", subType, superType));
+ return true;
+ }
+ return false;
}
void check(TreePath from) {
@@ -268,6 +306,7 @@ public class CompileBatch {
return field.getEnclosingElement() instanceof TypeElement;
}
+ // TODO what if instead we just make references really fast?
static List<Ptr> index(Trees trees, CompilationUnitTree root) {
var refs = new ArrayList<Ptr>();
class IndexFile extends TreePathScanner<Void, Void> {
@@ -289,6 +328,7 @@ public class CompileBatch {
return Optional.empty();
}
// TODO skip anything not on source path
+ // TODO this is also a reference to a bunch of other things
return Optional.of(to);
}
diff --git a/src/test/java/org/javacs/GotoTest.java b/src/test/java/org/javacs/GotoTest.java
index ac5d1cc..e92565c 100644
--- a/src/test/java/org/javacs/GotoTest.java
+++ b/src/test/java/org/javacs/GotoTest.java
@@ -147,6 +147,13 @@ public class GotoTest {
assertThat(doGoto(file, 5, 18), hasItems("GotoImplementation.java:9", "GotoImplementation.java:14"));
}
+ @Test
+ public void gotoError() {
+ String file = "/org/javacs/example/GotoError.java";
+
+ assertThat(doGoto(file, 5, 22), empty());
+ }
+
private static final JavaLanguageServer server = LanguageServerFixture.getJavaLanguageServer();
private List<String> doGoto(String file, int row, int column) {
diff --git a/src/test/test-project/workspace/src/org/javacs/example/GotoError.java b/src/test/test-project/workspace/src/org/javacs/example/GotoError.java
new file mode 100644
index 0000000..bf23b47
--- /dev/null
+++ b/src/test/test-project/workspace/src/org/javacs/example/GotoError.java
@@ -0,0 +1,7 @@
+package org.javacs.example;
+
+public class GotoError {
+ void main() {
+ ErrorThing.foo();
+ }
+} \ No newline at end of file