switch to mason.nvim
This commit is contained in:
parent
31cdc5d052
commit
d1074eeca2
@ -1,16 +1,16 @@
|
|||||||
local M = {}
|
local cfg = {}
|
||||||
|
|
||||||
-- debounce_text_changes = delay, between changing something and lsp updating
|
-- debounce_text_changes = delay, between changing something and lsp updating
|
||||||
M.flags = { debounce_text_changes = 150 }
|
cfg.flags = { debounce_text_changes = 150 }
|
||||||
|
|
||||||
local general_settings = { }
|
local general_settings = { }
|
||||||
M.server_init_options = {
|
cfg.server_init_options = {
|
||||||
efm = {
|
efm = {
|
||||||
documentFormatting = true
|
documentFormatting = true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
M.server_settings = {
|
cfg.server_settings = {
|
||||||
efm = {
|
efm = {
|
||||||
rootMarkers = {".git/"},
|
rootMarkers = {".git/"},
|
||||||
languages = {
|
languages = {
|
||||||
@ -84,19 +84,19 @@ M.server_settings = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
-- Apply general settings for each server
|
-- Apply general settings for each server
|
||||||
for _, settings in ipairs(M.server_settings) do
|
for _, settings in ipairs(cfg.server_settings) do
|
||||||
M.server_settings = vim.tbl_deep_extend("keep", settings, general_settings)
|
cfg.server_settings = vim.tbl_deep_extend("keep", settings, general_settings)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Use an on_attach function to only map the following keys
|
-- Use an on_attach function to only map the following keys
|
||||||
-- after the language server attaches to the current buffer
|
-- after the language server attaches to the current buffer
|
||||||
---@diagnostic disable-next-line: unused-local
|
---@diagnostic disable-next-line: unused-local
|
||||||
function M.on_attach(client, bufnr)
|
function cfg.on_attach(client, bufnr)
|
||||||
-- Mappings.
|
-- Mappings.
|
||||||
local opts = { noremap = true, silent = true, buffer = bufnr}
|
local opts = { noremap = true, silent = true, buffer = bufnr}
|
||||||
|
|
||||||
-- local function keymap(mode, lhs, rhs) vim.api.nvim_buf_set_keymap(bufnr, mode, lhs, rhs, opts) end
|
-- local function keymap(mode, lhs, rhs) vim.api.nvim_buf_set_keymap(bufnr, mode, lhs, rhs, opts) end
|
||||||
local function buf_set_option(...) vim.api.nvim_buf_set_option(bufnr, ...) end
|
local function buf_set_option(...) vim.api.nvim_buf_set_option(bufnr, ...) end
|
||||||
|
|
||||||
require("legendary").keymaps{
|
require("legendary").keymaps{
|
||||||
{
|
{
|
||||||
@ -114,22 +114,22 @@ function M.on_attach(client, bufnr)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
-- Enable completion triggered by <c-x><c-o>
|
-- Enable completion triggered by <c-x><c-o>
|
||||||
buf_set_option('omnifunc', 'v:lua.vim.lsp.omnifunc')
|
buf_set_option('omnifunc', 'v:lua.vim.lsp.omnifunc')
|
||||||
|
|
||||||
-- See `:help vim.lsp.*` for documentation on any of the below functions
|
-- See `:help vim.lsp.*` for documentation on any of the below functions
|
||||||
|
|
||||||
-- Conflicts with movement between panes
|
-- Conflicts with movement between panes
|
||||||
-- buf_set_keymap('n', '<C-k>', '<cmd>lua vim.lsp.buf.signature_help()<CR>')
|
-- buf_set_keymap('n', '<C-k>', '<cmd>lua vim.lsp.buf.signature_help()<CR>')
|
||||||
|
|
||||||
-- buf_set_keymap('n', '<space>wa', '<cmd>lua vim.lsp.buf.add_workspace_folder()<CR>')
|
-- buf_set_keymap('n', '<space>wa', '<cmd>lua vim.lsp.buf.add_workspace_folder()<CR>')
|
||||||
-- buf_set_keymap('n', '<space>wr', '<cmd>lua vim.lsp.buf.remove_workspace_folder()<CR>')
|
-- buf_set_keymap('n', '<space>wr', '<cmd>lua vim.lsp.buf.remove_workspace_folder()<CR>')
|
||||||
-- buf_set_keymap('n', '<space>wl', '<cmd>lua print(vim.inspect(vim.lsp.buf.list_workspace_folders()))<CR>')
|
-- buf_set_keymap('n', '<space>wl', '<cmd>lua print(vim.inspect(vim.lsp.buf.list_workspace_folders()))<CR>')
|
||||||
-- buf_set_keymap('n', '<space>D', '<cmd>lua vim.lsp.buf.type_definition()<CR>')
|
-- buf_set_keymap('n', '<space>D', '<cmd>lua vim.lsp.buf.type_definition()<CR>')
|
||||||
-- buf_set_keymap('n', '[d', '<cmd>lua vim.lsp.diagnostic.goto_prev()<CR>')
|
-- buf_set_keymap('n', '[d', '<cmd>lua vim.lsp.diagnostic.goto_prev()<CR>')
|
||||||
-- buf_set_keymap('n', ']d', '<cmd>lua vim.lsp.diagnostic.goto_next()<CR>')
|
-- buf_set_keymap('n', ']d', '<cmd>lua vim.lsp.diagnostic.goto_next()<CR>')
|
||||||
-- buf_set_keymap('n', '<space>q', '<cmd>lua vim.lsp.diagnostic.set_loclist()<CR>')
|
-- buf_set_keymap('n', '<space>q', '<cmd>lua vim.lsp.diagnostic.set_loclist()<CR>')
|
||||||
-- buf_set_keymap('n', '<space>f', '<cmd>lua vim.lsp.buf.formatting()<CR>')
|
-- buf_set_keymap('n', '<space>f', '<cmd>lua vim.lsp.buf.formatting()<CR>')
|
||||||
|
|
||||||
-- " auto-format
|
-- " auto-format
|
||||||
-- autocmd BufWritePre *.js lua vim.lsp.buf.formatting_sync(nil, 100)
|
-- autocmd BufWritePre *.js lua vim.lsp.buf.formatting_sync(nil, 100)
|
||||||
@ -137,7 +137,7 @@ function M.on_attach(client, bufnr)
|
|||||||
-- autocmd BufWritePre *.py lua vim.lsp.buf.formatting_sync(nil, 100)
|
-- autocmd BufWritePre *.py lua vim.lsp.buf.formatting_sync(nil, 100)
|
||||||
end
|
end
|
||||||
|
|
||||||
function M.get_capabilities()
|
function cfg.get_capabilities()
|
||||||
local capabilities = vim.lsp.protocol.make_client_capabilities()
|
local capabilities = vim.lsp.protocol.make_client_capabilities()
|
||||||
|
|
||||||
if packer_plugins['cmp-nvim-lsp'] and packer_plugins['cmp-nvim-lsp'].loaded then
|
if packer_plugins['cmp-nvim-lsp'] and packer_plugins['cmp-nvim-lsp'].loaded then
|
||||||
@ -147,7 +147,7 @@ function M.get_capabilities()
|
|||||||
return capabilities
|
return capabilities
|
||||||
end
|
end
|
||||||
|
|
||||||
function M.on_init(initialize_params, config)
|
function cfg.on_init(initialize_params, config)
|
||||||
-- print("lsp init")
|
-- print("lsp init")
|
||||||
|
|
||||||
-- TODO: Load settings from ".lspconfig.json" for each projects settings
|
-- TODO: Load settings from ".lspconfig.json" for each projects settings
|
||||||
@ -155,18 +155,12 @@ function M.on_init(initialize_params, config)
|
|||||||
-- https://github.com/neovim/nvim-lspconfig/wiki/Project-local-settings
|
-- https://github.com/neovim/nvim-lspconfig/wiki/Project-local-settings
|
||||||
end
|
end
|
||||||
|
|
||||||
function M.get_server_settings(name)
|
function cfg.get_server_settings(name)
|
||||||
return M.server_settings[name]
|
return cfg.server_settings[name]
|
||||||
end
|
end
|
||||||
|
|
||||||
function M.get_server_init_options(name)
|
function cfg.get_server_init_options(name)
|
||||||
return M.server_init_options[name]
|
return cfg.server_init_options[name]
|
||||||
end
|
end
|
||||||
|
|
||||||
---@diagnostic disable-next-line: empty-block
|
return cfg
|
||||||
if packer_plugins['nvim-lsp-installer'] and packer_plugins['nvim-lsp-installer'].loaded then
|
|
||||||
-- local lspconfig = require('lspconfig')
|
|
||||||
-- TODO: Manually do "server:setup{}" if lspinstaller is not loaded
|
|
||||||
end
|
|
||||||
|
|
||||||
return M
|
|
||||||
|
@ -1,39 +0,0 @@
|
|||||||
local lspconfig_config = require('config.lspconfig')
|
|
||||||
local lsp_installer = require('nvim-lsp-installer')
|
|
||||||
local lsp_installer_servers = require('nvim-lsp-installer.servers')
|
|
||||||
|
|
||||||
-- local autoinstall_servers = {"sumneko_lua", "efm"}
|
|
||||||
local autoinstall_servers = {"sumneko_lua"}
|
|
||||||
for _, name in ipairs(autoinstall_servers) do
|
|
||||||
local ok, server = lsp_installer_servers.get_server(name)
|
|
||||||
if ok and not server:is_installed() then
|
|
||||||
server:install()
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
local capabilities = lspconfig_config.get_capabilities()
|
|
||||||
|
|
||||||
for _, server in ipairs(lsp_installer.get_installed_servers()) do
|
|
||||||
local opts = {
|
|
||||||
root_dir = function()
|
|
||||||
return vim.fn.getcwd()
|
|
||||||
end,
|
|
||||||
init_options = lspconfig_config.get_server_init_options(server.name),
|
|
||||||
on_attach = lspconfig_config.on_attach,
|
|
||||||
on_init = lspconfig_config.on_init,
|
|
||||||
flags = lspconfig_config.flags,
|
|
||||||
capabilities = capabilities,
|
|
||||||
settings = lspconfig_config.get_server_settings(server.name)
|
|
||||||
}
|
|
||||||
|
|
||||||
if server.name == "rust_analyzer" then
|
|
||||||
local has_rust_tools, rust_tools = pcall(require, "rust-tools")
|
|
||||||
if has_rust_tools then
|
|
||||||
rust_tools.setup({ server = opts })
|
|
||||||
goto continue
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
server:setup(opts)
|
|
||||||
::continue::
|
|
||||||
end
|
|
@ -11,8 +11,8 @@ return {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
require("legendary").keymap{
|
-- require("legendary").keymap{
|
||||||
"<super>x", lsp_signature.toggle_float_win, description="Toggle signature float"
|
-- "<super>x", lsp_signature.toggle_float_win, description="Toggle signature float"
|
||||||
}
|
-- }
|
||||||
end
|
end
|
||||||
}
|
}
|
||||||
|
32
lua/config/mason-lspconfig.lua
Normal file
32
lua/config/mason-lspconfig.lua
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
local lspconfig_config = require('config.lspconfig')
|
||||||
|
|
||||||
|
local function get_options(server_name)
|
||||||
|
return {
|
||||||
|
root_dir = function()
|
||||||
|
return vim.fn.getcwd()
|
||||||
|
end,
|
||||||
|
init_options = lspconfig_config.get_server_init_options(server_name),
|
||||||
|
on_attach = lspconfig_config.on_attach,
|
||||||
|
on_init = lspconfig_config.on_init,
|
||||||
|
flags = lspconfig_config.flags,
|
||||||
|
capabilities = capabilities,
|
||||||
|
settings = lspconfig_config.get_server_settings(server_name)
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
require("mason-lspconfig").setup()
|
||||||
|
require("mason-lspconfig").setup_handlers{
|
||||||
|
function (server_name) -- default handler (optional)
|
||||||
|
require("lspconfig")[server_name].setup(get_options(server_name))
|
||||||
|
end,
|
||||||
|
["rust_analyzer"] = function ()
|
||||||
|
local opts = get_options(server_name)
|
||||||
|
|
||||||
|
local has_rust_tools, rust_tools = pcall(require, "rust-tools")
|
||||||
|
if has_rust_tools then
|
||||||
|
rust_tools.setup({ server = opts })
|
||||||
|
else
|
||||||
|
require("lspconfig")[server_name].setup(opts)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
}
|
1
lua/config/mason.lua
Normal file
1
lua/config/mason.lua
Normal file
@ -0,0 +1 @@
|
|||||||
|
require("mason").setup()
|
@ -45,14 +45,19 @@ return function(use)
|
|||||||
}
|
}
|
||||||
|
|
||||||
use {
|
use {
|
||||||
"neovim/nvim-lspconfig",
|
"williamboman/mason.nvim",
|
||||||
config_name = "lspconfig"
|
|
||||||
}
|
|
||||||
|
|
||||||
use {
|
|
||||||
'williamboman/nvim-lsp-installer',
|
|
||||||
requires = 'neovim/nvim-lspconfig',
|
requires = 'neovim/nvim-lspconfig',
|
||||||
config_name = "lspinstaller"
|
config_name = "mason"
|
||||||
|
}
|
||||||
|
use {
|
||||||
|
"williamboman/mason-lspconfig.nvim",
|
||||||
|
requires = "williamboman/mason.nvim",
|
||||||
|
config_name = "mason-lspconfig"
|
||||||
|
}
|
||||||
|
use {
|
||||||
|
"neovim/nvim-lspconfig",
|
||||||
|
requires = "williamboman/mason-lspconfig.nvim",
|
||||||
|
--config_name = "lspconfig"
|
||||||
}
|
}
|
||||||
|
|
||||||
use {
|
use {
|
||||||
|
Loading…
Reference in New Issue
Block a user