summaryrefslogtreecommitdiff
path: root/cli/lsp/language_server.rs
diff options
context:
space:
mode:
authorBartek IwaƄczuk <biwanczuk@gmail.com>2022-06-27 19:43:43 +0200
committerGitHub <noreply@github.com>2022-06-27 19:43:43 +0200
commit681bb49d0df0865a6564741544869a57aab56bb1 (patch)
tree142bae4a04e696d16490814f4c36116bc85adf5a /cli/lsp/language_server.rs
parent440250c05498e3bfc8682e91476dc6e0e3a79429 (diff)
fix(lsp): restart TS language service when caching dependencies (#14979)
Diffstat (limited to 'cli/lsp/language_server.rs')
-rw-r--r--cli/lsp/language_server.rs13
1 files changed, 10 insertions, 3 deletions
diff --git a/cli/lsp/language_server.rs b/cli/lsp/language_server.rs
index fdda1aeec..30a2ce253 100644
--- a/cli/lsp/language_server.rs
+++ b/cli/lsp/language_server.rs
@@ -2814,9 +2814,16 @@ impl Inner {
self.client.show_message(MessageType::WARNING, err).await;
}
- // now that we have dependencies loaded, we need to re-analyze them and
- // invalidate some diagnostics
- self.diagnostics_server.invalidate(&[referrer]);
+ // Now that we have dependencies loaded, we need to re-analyze all the files.
+ // For that we're invalidating all the existing diagnostics and restarting
+ // the language server for TypeScript (as it might hold to some stale
+ // documents).
+ self.diagnostics_server.invalidate_all();
+ let _: bool = self
+ .ts_server
+ .request(self.snapshot(), tsc::RequestMethod::Restart)
+ .await
+ .unwrap();
self.send_diagnostics_update();
self.send_testing_update();