summaryrefslogtreecommitdiff
path: root/lua/lvim/lsp/init.lua
diff options
context:
space:
mode:
authorkylo252 <[email protected]>2022-05-03 08:55:15 +0200
committerkylo252 <[email protected]>2022-05-03 08:55:15 +0200
commite264bff7e820ba891cd16892de52236d62f7821f (patch)
tree4262530ac7738ebdec0fa6abab560610789b72f3 /lua/lvim/lsp/init.lua
parentad5eeaf6ad12cf05e4b936690bf78bc53827b12c (diff)
parentcfa702e6fe2f875a2c674182fe2f86e8f613aa1e (diff)
Merge remote-tracking branch 'origin/rolling'
Diffstat (limited to 'lua/lvim/lsp/init.lua')
-rw-r--r--lua/lvim/lsp/init.lua55
1 files changed, 14 insertions, 41 deletions
diff --git a/lua/lvim/lsp/init.lua b/lua/lvim/lsp/init.lua
index a02ca426..13fafae0 100644
--- a/lua/lvim/lsp/init.lua
+++ b/lua/lvim/lsp/init.lua
@@ -3,23 +3,6 @@ local Log = require "lvim.core.log"
local utils = require "lvim.utils"
local autocmds = require "lvim.core.autocmds"
-local function lsp_highlight_document(client)
- if lvim.lsp.document_highlight == false then
- return -- we don't need further
- end
- autocmds.enable_lsp_document_highlight(client.id)
-end
-
-local function lsp_code_lens_refresh(client)
- if lvim.lsp.code_lens_refresh == false then
- return
- end
-
- if client.resolved_capabilities.code_lens then
- autocmds.enable_code_lens_refresh()
- end
-end
-
local function add_lsp_buffer_keybindings(bufnr)
local mappings = {
normal_mode = "n",
@@ -65,28 +48,12 @@ function M.common_capabilities()
return capabilities
end
-local function select_default_formater(client)
- if client.name == "null-ls" or not client.resolved_capabilities.document_formatting then
- return
- end
- Log:debug("Checking for formatter overriding for " .. client.name)
- local formatters = require "lvim.lsp.null-ls.formatters"
- local client_filetypes = client.config.filetypes or {}
- for _, filetype in ipairs(client_filetypes) do
- if #vim.tbl_keys(formatters.list_registered(filetype)) > 0 then
- Log:debug("Formatter overriding detected. Disabling formatting capabilities for " .. client.name)
- client.resolved_capabilities.document_formatting = false
- client.resolved_capabilities.document_range_formatting = false
- end
- end
-end
-
function M.common_on_exit(_, _)
if lvim.lsp.document_highlight then
- autocmds.disable_lsp_document_highlight()
+ pcall(vim.api.nvim_del_augroup_by_name, "lsp_document_highlight")
end
if lvim.lsp.code_lens_refresh then
- autocmds.disable_code_lens_refresh()
+ pcall(vim.api.nvim_del_augroup_by_name, "lsp_code_lens_refresh")
end
end
@@ -96,7 +63,6 @@ function M.common_on_init(client, bufnr)
Log:debug "Called lsp.on_init_callback"
return
end
- select_default_formater(client)
end
function M.common_on_attach(client, bufnr)
@@ -104,8 +70,13 @@ function M.common_on_attach(client, bufnr)
lvim.lsp.on_attach_callback(client, bufnr)
Log:debug "Called lsp.on_attach_callback"
end
- lsp_highlight_document(client)
- lsp_code_lens_refresh(client)
+ local lu = require "lvim.lsp.utils"
+ if lvim.lsp.document_highlight then
+ lu.setup_document_highlight(client, bufnr)
+ end
+ if lvim.lsp.code_lens_refresh == false then
+ lu.setup_codelens_refresh(client, bufnr)
+ end
add_lsp_buffer_keybindings(bufnr)
end
@@ -134,8 +105,10 @@ function M.setup()
return
end
- for _, sign in ipairs(lvim.lsp.diagnostics.signs.values) do
- vim.fn.sign_define(sign.name, { texthl = sign.name, text = sign.text, numhl = sign.name })
+ if lvim.use_icons then
+ for _, sign in ipairs(lvim.lsp.diagnostics.signs.values) do
+ vim.fn.sign_define(sign.name, { texthl = sign.name, text = sign.text, numhl = sign.name })
+ end
end
require("lvim.lsp.handlers").setup()
@@ -149,7 +122,7 @@ function M.setup()
append_default_schemas = true,
}
- require("nvim-lsp-installer").settings {
+ require("nvim-lsp-installer").setup {
-- use the default nvim_data_dir, since the server binaries are independent
install_root_dir = utils.join_paths(vim.call("stdpath", "data"), "lsp_servers"),
}