From 918cba4cce84f9c76e8ebbc93e3f7392964f341a Mon Sep 17 00:00:00 2001 From: Piotr Osiewicz <24362066+osiewicz@users.noreply.github.com> Date: Sun, 23 Feb 2025 01:17:46 +0100 Subject: [PATCH] lsp: Check for existing snapshots before sending off a didOpen notification (#25409) Closes #ISSUE Release Notes: - Fixed Zed sending out didOpen notification to a language server when opening documents. --- crates/project/src/lsp_store.rs | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) diff --git a/crates/project/src/lsp_store.rs b/crates/project/src/lsp_store.rs index 632b96c8b7..0c89f5c0f1 100644 --- a/crates/project/src/lsp_store.rs +++ b/crates/project/src/lsp_store.rs @@ -1921,17 +1921,20 @@ impl LocalLspStore { version: 0, snapshot: initial_snapshot.clone(), }; - self.buffer_snapshots + let previous_snapshots = self + .buffer_snapshots .entry(buffer_id) .or_default() .insert(server.server_id(), vec![snapshot]); - server.register_buffer( - uri.clone(), - adapter.language_id(&language.name()), - 0, - initial_snapshot.text(), - ); + if previous_snapshots.is_none() { + server.register_buffer( + uri.clone(), + adapter.language_id(&language.name()), + 0, + initial_snapshot.text(), + ); + } } } }