From 5ac8db10f0428c976dfc9a4935a74d0fe160995c Mon Sep 17 00:00:00 2001 From: Andre Toerien <49614525+AThePeanut4@users.noreply.github.com> Date: Thu, 23 May 2024 12:03:47 +0200 Subject: fix(lsp): trigger LspDetach on buffer delete (#28795) Co-authored-by: Mathias Fussenegger --- runtime/lua/vim/lsp.lua | 9 +++++++++ 1 file changed, 9 insertions(+) (limited to 'runtime') diff --git a/runtime/lua/vim/lsp.lua b/runtime/lua/vim/lsp.lua index ad1794e98d..700c10abc8 100644 --- a/runtime/lua/vim/lsp.lua +++ b/runtime/lua/vim/lsp.lua @@ -576,10 +576,19 @@ local function buf_attach(bufnr) on_detach = function() local params = { textDocument = { uri = uri } } for _, client in ipairs(lsp.get_clients({ bufnr = bufnr })) do + api.nvim_exec_autocmds('LspDetach', { + buffer = bufnr, + modeline = false, + data = { client_id = client.id }, + }) + changetracking.reset_buf(client, bufnr) if client.supports_method(ms.textDocument_didClose) then client.notify(ms.textDocument_didClose, params) end + + local namespace = lsp.diagnostic.get_namespace(client.id) + vim.diagnostic.reset(namespace, bufnr) end for _, client in ipairs(all_clients) do client.attached_buffers[bufnr] = nil -- cgit