summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/main/java/org/javacs/Cache.java9
-rw-r--r--src/main/java/org/javacs/FileStore.java34
-rw-r--r--src/main/java/org/javacs/JavaLanguageServer.java3
3 files changed, 38 insertions, 8 deletions
diff --git a/src/main/java/org/javacs/Cache.java b/src/main/java/org/javacs/Cache.java
index 139d1e1..f08270f 100644
--- a/src/main/java/org/javacs/Cache.java
+++ b/src/main/java/org/javacs/Cache.java
@@ -1,7 +1,5 @@
package org.javacs;
-import java.io.IOException;
-import java.nio.file.Files;
import java.nio.file.Path;
import java.time.Instant;
import java.util.HashMap;
@@ -50,12 +48,7 @@ class Cache<K, V> {
// If key was loaded before file was last modified, it needs to be reloaded
var value = map.get(key);
- Instant modified;
- try {
- modified = Files.getLastModifiedTime(file).toInstant();
- } catch (IOException e) {
- throw new RuntimeException(e);
- }
+ var modified = FileStore.modified(file);
return value.created.isBefore(modified);
}
diff --git a/src/main/java/org/javacs/FileStore.java b/src/main/java/org/javacs/FileStore.java
index 8f60e25..f3648d6 100644
--- a/src/main/java/org/javacs/FileStore.java
+++ b/src/main/java/org/javacs/FileStore.java
@@ -6,7 +6,9 @@ import java.io.StringReader;
import java.io.StringWriter;
import java.net.URI;
import java.nio.file.Files;
+import java.nio.file.Path;
import java.nio.file.Paths;
+import java.time.Instant;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
@@ -20,6 +22,38 @@ import org.javacs.lsp.TextDocumentContentChangeEvent;
class FileStore {
private static final Map<URI, VersionedContent> activeDocuments = new HashMap<>();
+ private static final Map<Path, Instant> modified = new HashMap<>();
+
+ static Instant modified(Path file) {
+ // If we've never checked before, look up modified time on disk
+ if (!modified.containsKey(file)) {
+ readModifiedFromDisk(file);
+ }
+
+ // Look up modified time from cache
+ return modified.get(file);
+ }
+
+ static void externalCreate(Path file) {
+ readModifiedFromDisk(file);
+ }
+
+ static void externalChange(Path file) {
+ readModifiedFromDisk(file);
+ }
+
+ static void externalDelete(Path file) {
+ modified.remove(file);
+ }
+
+ private static void readModifiedFromDisk(Path file) {
+ try {
+ var time = Files.getLastModifiedTime(file).toInstant();
+ modified.put(file, time);
+ } catch (IOException e) {
+ throw new RuntimeException(e);
+ }
+ }
static boolean isJavaFile(URI uri) {
return uri.getScheme().equals("file") && uri.getPath().endsWith(".java");
diff --git a/src/main/java/org/javacs/JavaLanguageServer.java b/src/main/java/org/javacs/JavaLanguageServer.java
index 32d4bdf..2a6ee1b 100644
--- a/src/main/java/org/javacs/JavaLanguageServer.java
+++ b/src/main/java/org/javacs/JavaLanguageServer.java
@@ -268,12 +268,15 @@ class JavaLanguageServer extends LanguageServer {
var file = Paths.get(c.uri);
switch (c.type) {
case FileChangeType.Created:
+ FileStore.externalCreate(file);
created.add(file);
break;
case FileChangeType.Changed:
+ FileStore.externalChange(file);
if (sourcePath.update(file)) changed = true;
break;
case FileChangeType.Deleted:
+ FileStore.externalDelete(file);
deleted.add(file);
break;
}