summaryrefslogtreecommitdiff
path: root/lua/user/lsp/lsp-installer.lua
diff options
context:
space:
mode:
authorVito G. Graffagnino <vito@graffagnino.xyz>2022-06-03 14:51:10 +0100
committerVito G. Graffagnino <vito@graffagnino.xyz>2022-06-03 14:51:10 +0100
commit00f61b3600ef40c0a94a3897a5da6d7d3de8b39a (patch)
tree4e134da1376d8506fbc0c4b2177535cd8c2b3f5a /lua/user/lsp/lsp-installer.lua
parent87b3c29b07ff5390188af5815e0290c854549829 (diff)
parente60e3e816a1f9fe8338733734286c3c56e58f944 (diff)
Merge branch '06-LSP' into vgg
Diffstat (limited to 'lua/user/lsp/lsp-installer.lua')
-rw-r--r--lua/user/lsp/lsp-installer.lua33
1 files changed, 33 insertions, 0 deletions
diff --git a/lua/user/lsp/lsp-installer.lua b/lua/user/lsp/lsp-installer.lua
new file mode 100644
index 0000000..f539050
--- /dev/null
+++ b/lua/user/lsp/lsp-installer.lua
@@ -0,0 +1,33 @@
+local status_ok, lsp_installer = pcall(require, "nvim-lsp-installer")
+if not status_ok then
+ return
+end
+
+-- Register a handler that will be called for all installed servers.
+-- Alternatively, you may also register handlers on specific server instances instead (see example below).
+lsp_installer.on_server_ready(function(server)
+ local opts = {
+ on_attach = require("user.lsp.handlers").on_attach,
+ capabilities = require("user.lsp.handlers").capabilities,
+ }
+
+ if server.name == "jsonls" then
+ local jsonls_opts = require("user.lsp.settings.jsonls")
+ opts = vim.tbl_deep_extend("force", jsonls_opts, opts)
+ end
+
+ if server.name == "sumneko_lua" then
+ local sumneko_opts = require("user.lsp.settings.sumneko_lua")
+ opts = vim.tbl_deep_extend("force", sumneko_opts, opts)
+ end
+
+ if server.name == "pyright" then
+ local pyright_opts = require("user.lsp.settings.pyright")
+ opts = vim.tbl_deep_extend("force", pyright_opts, opts)
+ end
+
+ -- This setup() function is exactly the same as lspconfig's setup function.
+ -- Refer to https://github.com/neovim/nvim-lspconfig/blob/master/doc/server_configurations.md
+ server:setup(opts)
+end)
+