From 5c17ad21d2e902df6fc633cca0d57adaf2714ad8 Mon Sep 17 00:00:00 2001 From: Fabrice Mouhartem Date: Tue, 1 Apr 2025 18:46:26 +0200 Subject: [PATCH] feat(lsp): replace on_attach with an LspAttach rule --- lua/lsp.lua | 97 ++++++++++++++++++++++++++++------------------------- 1 file changed, 51 insertions(+), 46 deletions(-) diff --git a/lua/lsp.lua b/lua/lsp.lua index 857fc66..7f5b5b3 100644 --- a/lua/lsp.lua +++ b/lua/lsp.lua @@ -1,55 +1,60 @@ +local lspattach = vim.api.nvim_create_augroup("LspMapping", { clear = true }) + -- This function gets run when an LSP connects to a particular buffer. -local on_attach = function(_, bufnr) - -- NOTE: Remember that lua is a real programming language, and as such it is possible - -- to define small helper and utility functions so you don't have to repeat yourself - -- many times. - -- - -- In this case, we create a function that lets us more easily define mappings specific - -- for LSP related items. It sets the mode, buffer and description for us each time. - local nmap = function(keys, func, desc) - if desc then - desc = 'LSP: ' .. desc +vim.api.nvim_create_autocmd("LspAttach", { + group = lspattach, + callback = function(args) + -- NOTE: Remember that lua is a real programming language, and as such it is possible + -- to define small helper and utility functions so you don't have to repeat yourself + -- many times. + -- + -- In this case, we create a function that lets us more easily define mappings specific + -- for LSP related items. It sets the mode, buffer and description for us each time. + local nmap = function(keys, func, desc) + if desc then + desc = 'LSP: ' .. desc + end + + vim.keymap.set('n', keys, func, { buffer = args.buf, silent = true, desc = desc }) end - vim.keymap.set('n', keys, func, { buffer = bufnr, desc = desc }) - end + nmap('rn', vim.lsp.buf.rename, '[R]e[n]ame') + nmap('c', vim.lsp.buf.code_action, '[C]ode action') -- NOTE: to see if ca is needed + nmap('f', function() -- https://stackoverflow.com/a/74303272 + vim.lsp.buf.code_action({ + filter = function(a) + return a.isPreferred + end, + apply = true + }) + end, 'code action: [F]ix' + ) - nmap('rn', vim.lsp.buf.rename, '[R]e[n]ame') - nmap('c', vim.lsp.buf.code_action, '[C]ode action') -- NOTE: to see if ca is needed - nmap('f', function() -- https://stackoverflow.com/a/74303272 - vim.lsp.buf.code_action({ - filter = function(a) - return a.isPreferred - end, - apply = true - }) - end, 'code action: [F]ix' - ) + nmap('gd', require('telescope.builtin').lsp_definitions, '[G]oto [D]efinition') + nmap('gr', require('telescope.builtin').lsp_references, '[G]oto [R]eferences') + nmap('gI', require('telescope.builtin').lsp_implementations, '[G]oto [I]mplementation') + nmap('D', require('telescope.builtin').lsp_type_definitions, 'Type [D]efinition') + nmap('ds', require('telescope.builtin').lsp_document_symbols, '[D]ocument [S]ymbols') + nmap('ws', require('telescope.builtin').lsp_dynamic_workspace_symbols, '[W]orkspace [S]ymbols') - nmap('gd', require('telescope.builtin').lsp_definitions, '[G]oto [D]efinition') - nmap('gr', require('telescope.builtin').lsp_references, '[G]oto [R]eferences') - nmap('gI', require('telescope.builtin').lsp_implementations, '[G]oto [I]mplementation') - nmap('D', require('telescope.builtin').lsp_type_definitions, 'Type [D]efinition') - nmap('ds', require('telescope.builtin').lsp_document_symbols, '[D]ocument [S]ymbols') - nmap('ws', require('telescope.builtin').lsp_dynamic_workspace_symbols, '[W]orkspace [S]ymbols') + -- See `:help K` for why this keymap + nmap('K', vim.lsp.buf.hover, 'Hover Documentation') + nmap('', vim.lsp.buf.signature_help, 'Signature Documentation') - -- See `:help K` for why this keymap - nmap('K', vim.lsp.buf.hover, 'Hover Documentation') - nmap('', vim.lsp.buf.signature_help, 'Signature Documentation') + -- Lesser used LSP functionality + nmap('gD', vim.lsp.buf.declaration, '[G]oto [D]eclaration') + nmap('wa', vim.lsp.buf.add_workspace_folder, '[W]orkspace [A]dd Folder') + nmap('wr', vim.lsp.buf.remove_workspace_folder, '[W]orkspace [R]emove Folder') + nmap('wl', function() + print(vim.inspect(vim.lsp.buf.list_workspace_folders())) + end, '[W]orkspace [L]ist Folders') - -- Lesser used LSP functionality - nmap('gD', vim.lsp.buf.declaration, '[G]oto [D]eclaration') - nmap('wa', vim.lsp.buf.add_workspace_folder, '[W]orkspace [A]dd Folder') - nmap('wr', vim.lsp.buf.remove_workspace_folder, '[W]orkspace [R]emove Folder') - nmap('wl', function() - print(vim.inspect(vim.lsp.buf.list_workspace_folders())) - end, '[W]orkspace [L]ist Folders') - - -- Create a command `:Format` local to the LSP buffer - vim.api.nvim_buf_create_user_command(bufnr, 'Format', function(_) - vim.lsp.buf.format() - end, { desc = 'Format current buffer with LSP' }) -end + -- Create a command `:Format` local to the LSP buffer + vim.api.nvim_buf_create_user_command(args.buf, 'Format', function(_) + vim.lsp.buf.format() + end, { desc = 'Format current buffer with LSP' }) + end, +}) -- document existing key chains require('which-key').add { @@ -186,7 +191,7 @@ local setup_godot_dap = function() } end -vim.diagnostic.config({ virtual_lines = true }) +vim.diagnostic.config({ virtual_text = true }) vim.lsp.enable({ "ltex_plus" }) setup_godot_dap()