diff --git a/lua/lazyvim/plugins/lsp/keymaps.lua b/lua/lazyvim/plugins/lsp/keymaps.lua index c26058dc7..9bdc87819 100644 --- a/lua/lazyvim/plugins/lsp/keymaps.lua +++ b/lua/lazyvim/plugins/lsp/keymaps.lua @@ -6,30 +6,46 @@ M._keys = nil ---@return (LazyKeys|{has?:string})[] function M.get() local format = require("lazyvim.plugins.lsp.format").format + if not M._keys then ---@class PluginLspKeys - -- stylua: ignore - M._keys = M._keys or { - { "cd", vim.diagnostic.open_float, desc = "Line Diagnostics" }, - { "cl", "LspInfo", desc = "Lsp Info" }, - { "gd", "Telescope lsp_definitions", desc = "Goto Definition" }, - { "gr", "Telescope lsp_references", desc = "References" }, - { "gD", vim.lsp.buf.declaration, desc = "Goto Declaration" }, - { "gI", "Telescope lsp_implementations", desc = "Goto Implementation" }, - { "gt", "Telescope lsp_type_definitions", desc = "Goto Type Definition" }, - { "K", vim.lsp.buf.hover, desc = "Hover" }, - { "gK", vim.lsp.buf.signature_help, desc = "Signature Help", has = "signatureHelp" }, - { "", vim.lsp.buf.signature_help, mode = "i", desc = "Signature Help", has = "signatureHelp" }, - { "]d", M.diagnostic_goto(true), desc = "Next Diagnostic" }, - { "[d", M.diagnostic_goto(false), desc = "Prev Diagnostic" }, - { "]e", M.diagnostic_goto(true, "ERROR"), desc = "Next Error" }, - { "[e", M.diagnostic_goto(false, "ERROR"), desc = "Prev Error" }, - { "]w", M.diagnostic_goto(true, "WARN"), desc = "Next Warning" }, - { "[w", M.diagnostic_goto(false, "WARN"), desc = "Prev Warning" }, - { "ca", vim.lsp.buf.code_action, desc = "Code Action", mode = { "n", "v" }, has = "codeAction" }, - { "cf", format, desc = "Format Document", has = "documentFormatting" }, - { "cf", format, desc = "Format Range", mode = "v", has = "documentRangeFormatting" }, - { "cr", M.rename, expr = true, desc = "Rename", has = "rename" }, - } + -- stylua: ignore + M._keys = { + { "cd", vim.diagnostic.open_float, desc = "Line Diagnostics" }, + { "cl", "LspInfo", desc = "Lsp Info" }, + { "gd", "Telescope lsp_definitions", desc = "Goto Definition" }, + { "gr", "Telescope lsp_references", desc = "References" }, + { "gD", vim.lsp.buf.declaration, desc = "Goto Declaration" }, + { "gI", "Telescope lsp_implementations", desc = "Goto Implementation" }, + { "gt", "Telescope lsp_type_definitions", desc = "Goto Type Definition" }, + { "K", vim.lsp.buf.hover, desc = "Hover" }, + { "gK", vim.lsp.buf.signature_help, desc = "Signature Help", has = "signatureHelp" }, + { "", vim.lsp.buf.signature_help, mode = "i", desc = "Signature Help", has = "signatureHelp" }, + { "]d", M.diagnostic_goto(true), desc = "Next Diagnostic" }, + { "[d", M.diagnostic_goto(false), desc = "Prev Diagnostic" }, + { "]e", M.diagnostic_goto(true, "ERROR"), desc = "Next Error" }, + { "[e", M.diagnostic_goto(false, "ERROR"), desc = "Prev Error" }, + { "]w", M.diagnostic_goto(true, "WARN"), desc = "Next Warning" }, + { "[w", M.diagnostic_goto(false, "WARN"), desc = "Prev Warning" }, + { "ca", vim.lsp.buf.code_action, desc = "Code Action", mode = { "n", "v" }, has = "codeAction" }, + { "cf", format, desc = "Format Document", has = "documentFormatting" }, + { "cf", format, desc = "Format Range", mode = "v", has = "documentRangeFormatting" }, + } + if require("lazyvim.util").has("inc-rename.nvim") then + M._keys[#M._keys + 1] = { + "cr", + function() + require("inc_rename") + return ":IncRename " .. vim.fn.expand("") + end, + expr = true, + desc = "Rename", + has = "rename", + } + else + M._keys[#M._keys + 1] = { "cr", vim.lsp.buf.rename, desc = "Rename", has = "rename" } + end + dd(M._keys) + end return M._keys end @@ -58,14 +74,6 @@ function M.on_attach(client, buffer) end end -function M.rename() - if pcall(require, "inc_rename") then - return ":IncRename " .. vim.fn.expand("") - else - vim.lsp.buf.rename() - end -end - function M.diagnostic_goto(next, severity) local go = next and vim.diagnostic.goto_next or vim.diagnostic.goto_prev severity = severity and vim.diagnostic.severity[severity] or nil