| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192 | local M = {}local Log = require "lvim.core.log"local lvim_lsp_utils = require "lvim.lsp.utils"function M.init_defaults(languages)  for _, entry in ipairs(languages) do    if not lvim.lang[entry] then      lvim.lang[entry] = {        formatters = {},        linters = {},        lsp = {},      }    end  endend---Resolve the configuration for a server based on both common and user configuration---@param name string---@param user_config table [optional]---@return tablelocal function resolve_config(name, user_config)  local config = {    on_attach = require("lvim.lsp").common_on_attach,    on_init = require("lvim.lsp").common_on_init,    capabilities = require("lvim.lsp").common_capabilities(),  }  local has_custom_provider, custom_config = pcall(require, "lvim/lsp/providers/" .. name)  if has_custom_provider then    Log:debug("Using custom configuration for requested server: " .. name)    config = vim.tbl_deep_extend("force", config, custom_config)  end  if user_config then    config = vim.tbl_deep_extend("force", config, user_config)  end  return configend-- manually start the server and don't wait for the usual filetype trigger from lspconfiglocal function buf_try_add(server_name, bufnr)  bufnr = bufnr or vim.api.nvim_get_current_buf()  require("lspconfig")[server_name].manager.try_add_wrapper(bufnr)end---Setup a language server by providing a name---@param server_name string name of the language server---@param user_config table [optional] when available it will take predence over any default configurationsfunction M.setup(server_name, user_config)  vim.validate { name = { server_name, "string" } }  if lvim_lsp_utils.is_client_active(server_name) then    return  end  local servers = require "nvim-lsp-installer.servers"  local config = resolve_config(server_name, user_config)  local server_available, requested_server = servers.get_server(server_name)  if server_available then    local install_notification = false    if not requested_server:is_installed() then      if lvim.lsp.automatic_servers_installation then        Log:debug "Automatic server installation detected"        requested_server:install()        install_notification = true      else        Log:debug(requested_server.name .. " is not managed by the automatic installer")      end    end    requested_server:on_ready(function()      if install_notification then        vim.notify(string.format("Installation complete for [%s] server", requested_server.name), vim.log.levels.INFO)      end      install_notification = false      requested_server:setup(config)    end)  else    -- since it may not be installed, don't attempt to configure the LSP unless there is a custom provider    local has_custom_provider, _ = pcall(require, "lvim/lsp/providers/" .. server_name)    if has_custom_provider then      require("lspconfig")[server_name].setup(config)      buf_try_add(server_name)    end  endendreturn M
 |