aboutsummaryrefslogtreecommitdiff
path: root/helix-term
diff options
context:
space:
mode:
authorPhilipp Mildenberger2023-03-19 18:26:39 +0000
committerPhilipp Mildenberger2023-05-18 19:48:32 +0000
commit58c913ce4567a95c52808d78245eb1dac806971c (patch)
tree17cd34fb69639a01337e800a1273db53bdcec717 /helix-term
parent7d20740b5b2e115e3075251204ee1ff1901166df (diff)
Simplify 'lsp_stop' command
Diffstat (limited to 'helix-term')
-rw-r--r--helix-term/src/commands/typed.rs53
1 files changed, 5 insertions, 48 deletions
diff --git a/helix-term/src/commands/typed.rs b/helix-term/src/commands/typed.rs
index 5f94b7c4..8cfc9fd2 100644
--- a/helix-term/src/commands/typed.rs
+++ b/helix-term/src/commands/typed.rs
@@ -1442,62 +1442,19 @@ fn lsp_stop(
return Ok(());
}
- let doc = doc!(cx.editor);
-
- // TODO this stops language servers which may be used in another doc/language type that uses the same language servers
- // I'm not sure if this is really what we want
- let ls_shutdown_names = doc
+ let ls_shutdown_names = doc!(cx.editor)
.language_servers()
- .map(|ls| ls.name())
+ .map(|ls| ls.name().to_string())
.collect::<Vec<_>>();
for ls_name in &ls_shutdown_names {
cx.editor.language_servers.stop(ls_name);
- }
- let doc_ids_active_clients: Vec<_> = cx
- .editor
- .documents()
- .filter_map(|doc| {
- let doc_active_ls_ids: Vec<_> = doc
- .language_servers()
- .filter(|ls| !ls_shutdown_names.contains(&ls.name()))
- .map(|ls| ls.id())
- .collect();
-
- let active_clients: Vec<_> = cx
- .editor
- .language_servers
- .iter_clients()
- .filter(|client| doc_active_ls_ids.contains(&client.id()))
- .map(Clone::clone)
- .collect();
-
- if active_clients.len() != doc.language_servers().count() {
- Some((doc.id(), active_clients))
- } else {
- None
+ for doc in cx.editor.documents_mut() {
+ if let Some(client) = doc.remove_language_server_by_name(ls_name) {
+ doc.clear_diagnostics(client.id());
}
- })
- .collect();
-
- for (doc_id, active_clients) in doc_ids_active_clients {
- let doc = cx.editor.documents.get_mut(&doc_id).unwrap();
-
- let stopped_clients: Vec<_> = doc
- .language_servers()
- .filter(|ls| {
- !active_clients
- .iter()
- .any(|active_ls| active_ls.id() == ls.id())
- })
- .map(|ls| ls.id())
- .collect(); // is necessary because of borrow-checking
-
- for client_id in stopped_clients {
- doc.clear_diagnostics(client_id)
}
- doc.set_language_servers(active_clients);
}
Ok(())