From 64acfae58765af449a00dc42af214cc83ac6c199 Mon Sep 17 00:00:00 2001 From: Grzegorz Rozdzialik Date: Thu, 28 Apr 2022 09:12:08 +0200 Subject: [PATCH] chore(nvim): use lspconfig to setup LSP servers Stop using nvim-lsp-installer's `on_server_ready` callback to set up servers. This is due to the recent breaking changes in `nvim-lsp-installer`. It recommends using lspconfig directly to set up the servers. This slightly simplifies the configuration, because there is no indirection of using the `Server` type from nvim-lsp-installer. See https://github.com/williamboman/nvim-lsp-installer/pull/631 --- .../stowed/.config/nvim/lua/lsp/init.lua | 58 +++++++++---------- 1 file changed, 26 insertions(+), 32 deletions(-) diff --git a/install/neovim/stowed/.config/nvim/lua/lsp/init.lua b/install/neovim/stowed/.config/nvim/lua/lsp/init.lua index 6fe428b6..975138c5 100644 --- a/install/neovim/stowed/.config/nvim/lua/lsp/init.lua +++ b/install/neovim/stowed/.config/nvim/lua/lsp/init.lua @@ -1,48 +1,42 @@ local utils = require("lsp.utils") local lsp_installer = require("nvim-lsp-installer") -local function setup_server_with_config(config) - ---@param server Server - return function(server) - return server:setup(config) - end -end +lsp_installer.setup({}) -local default_server_handler = setup_server_with_config(utils.base_config) +local default_server_config = utils.base_config ----Custom handlers for known LSP servers. ----`nil` will use the default handler with the default config. ----Presence of a server in this config means it will get installed +---Configs for known LSP servers. +---Presence of a server in this table means it will get installed ---by `:InstallDefaultLspServers` -local server_handlers = { +local server_configs = { -- Use null_ls for formatting - gopls = setup_server_with_config(utils.base_config_without_formatting), - jsonls = setup_server_with_config(require("lsp.jsonls").config), + gopls = utils.base_config_without_formatting, + jsonls = require("lsp.jsonls").config, -- Conflicts with prettier formatting in TS files. - stylelint_lsp = setup_server_with_config(utils.base_config_without_formatting), - sumneko_lua = setup_server_with_config(require("lsp.lua").config), - tsserver = setup_server_with_config(require("lsp.tsserver").config), - texlab = setup_server_with_config(require("lsp.tex").config), - rust_analyzer = default_server_handler, - bashls = default_server_handler, - cssls = default_server_handler, - svelte = default_server_handler, - eslint = default_server_handler, - yamlls = default_server_handler, - vimls = default_server_handler, + stylelint_lsp = utils.base_config_without_formatting, + sumneko_lua = require("lsp.lua").config, + tsserver = require("lsp.tsserver").config, + texlab = require("lsp.tex").config, + rust_analyzer = default_server_config, + bashls = default_server_config, + cssls = default_server_config, + svelte = default_server_config, + eslint = default_server_config, + yamlls = default_server_config, + vimls = default_server_config, } -lsp_installer.on_server_ready(function(server) - local custom_handler = server_handlers[server.name] - if custom_handler ~= nil then - custom_handler(server) - else - server:setup(utils.base_config) +local lspconfig = require("lspconfig") +local function setup_lsp_servers() + for server_name, server_config in pairs(server_configs) do + lspconfig[server_name].setup(server_config) end -end) +end + +setup_lsp_servers() vim.api.nvim_create_user_command("InstallDefaultLspServers", function() - for server_name in pairs(server_handlers) do + for server_name in pairs(server_configs) do lsp_installer.install(server_name) end end, {})