diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/main/java/org/javacs/CompileBatch.java | 54 | ||||
-rw-r--r-- | src/test/java/org/javacs/GotoTest.java | 7 | ||||
-rw-r--r-- | src/test/test-project/workspace/src/org/javacs/example/GotoError.java | 7 |
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 |