diff --git a/lua/custom/default.lua b/lua/custom/default.lua index bc93d57..6e0c339 100644 --- a/lua/custom/default.lua +++ b/lua/custom/default.lua @@ -73,19 +73,19 @@ vim.g.pcode_format_on_save = 1 -- untuk referesi support language kunjungi link dibawah -- https://github.com/neovim/nvim-lspconfig/blob/master/doc/server_configurations.md vim.g.pcode_lsp_installer = { - "yamlls", + -- "yamlls", -- tambahkan di bawah sini setelah melakukan :masoninstall } -- untuk referesi support language kunjungi link dibawah -- https://github.com/neovim/nvim-lspconfig/blob/master/doc/server_configurations.md vim.g.pcode_register_lsp = { "yamlls", - "intelephense", - "marksman", - "csharp_ls", - "clangd", - "dartls", - "kotlin_language_server", + -- "intelephense", + -- "marksman", + -- "csharp_ls", + -- "clangd", + -- "dartls", + -- "kotlin_language_server", -- tambahkan di bawah sini setelah melakukan :masoninstall } vim.g.pcode_unregister_lsp = { diff --git a/lua/user/lsp/mason.lua b/lua/user/lsp/mason.lua index 9e249f7..e7777ed 100644 --- a/lua/user/lsp/mason.lua +++ b/lua/user/lsp/mason.lua @@ -1,11 +1,5 @@ local servers = { - "sumneko_lua", - "cssls", - "html", - "tsserver", - "pyright", - "jsonls", - "emmet_ls", + "lua_ls", } local function idxOf(array, value) @@ -24,15 +18,11 @@ if data_exists then end end +local unregis_lsp = {} local data_ok, unregis = pcall(require, "core.config") if data_ok then if unregis.unregister_lsp ~= nil then - for _, unreg in pairs(unregis.unregister_lsp) do - local my_index = idxOf(servers, unreg) - if my_index ~= nil then - table.remove(servers, my_index) - end - end + unregis_lsp = unregis.unregister_lsp end end @@ -51,13 +41,13 @@ local settings = { require("mason").setup(settings) -- * buka remark ini jika akan menggunakan list serverrs diatas dan remark config dibawah --- require("mason-lspconfig").setup({ --- ensure_installed = servers, --- automatic_installation = true, --- }) +require("mason-lspconfig").setup({ + ensure_installed = servers, + automatic_installation = true, +}) -- -- * buka remark ini jika ingin menjalankan dengan cara install dan remark config diatas (pilih satu) -require("mason-lspconfig").setup() +-- require("mason-lspconfig").setup() local lspconfig_status_ok, lspconfig = pcall(require, "lspconfig") if not lspconfig_status_ok then @@ -66,18 +56,44 @@ end local opts = {} -for _, server in pairs(servers) do - opts = { - on_attach = require("user.lsp.handlers").on_attach, - capabilities = require("user.lsp.handlers").capabilities, - } +require("mason-lspconfig").setup_handlers({ + function(server_name) -- default handler (optional) + local is_skip = false + local my_index = idxOf(unregis_lsp, server_name) + if my_index ~= nil then + is_skip = true + end + if not is_skip then + if server_name == "lua_ls" then + server_name = "sumneko_lua" + end + opts = { + on_attach = require("user.lsp.handlers").on_attach, + capabilities = require("user.lsp.handlers").capabilities, + } - server = vim.split(server, "@")[1] + server_name = vim.split(server_name, "@")[1] - local require_ok, conf_opts = pcall(require, "user.lsp.settings." .. server) - if require_ok then - opts = vim.tbl_deep_extend("force", conf_opts, opts) - end - - lspconfig[server].setup(opts) -end + local require_ok, conf_opts = pcall(require, "user.lsp.settings." .. server_name) + if require_ok then + opts = vim.tbl_deep_extend("force", conf_opts, opts) + end + lspconfig[server_name].setup(opts) + end + end, + -- Next, you can provide targeted overrides for specific servers. + -- ["rust_analyzer"] = function() + -- require("rust-tools").setup({}) + -- end, + -- ["lua_ls"] = function() + -- lspconfig.sumneko_lua.setup({ + -- settings = { + -- Lua = { + -- diagnostics = { + -- globals = { "vim" }, + -- }, + -- }, + -- }, + -- }) + -- end, +}) diff --git a/lua/user/lsp/mason_20230306.lua b/lua/user/lsp/mason_20230306.lua new file mode 100644 index 0000000..5245f85 --- /dev/null +++ b/lua/user/lsp/mason_20230306.lua @@ -0,0 +1,83 @@ +local servers = { + "sumneko_lua", + "cssls", + "html", + "tsserver", + "pyright", + "jsonls", + "emmet_ls", +} + +local function idxOf(array, value) + for i, v in ipairs(array) do + if v == value then + return i + end + end + return nil +end + +local data_exists, custom_lsp = pcall(require, "core.config") +if data_exists then + for _, client in pairs(custom_lsp.register_lsp) do + table.insert(servers, client) + end +end + +local data_ok, unregis = pcall(require, "core.config") +if data_ok then + if unregis.unregister_lsp ~= nil then + for _, unreg in pairs(unregis.unregister_lsp) do + local my_index = idxOf(servers, unreg) + if my_index ~= nil then + table.remove(servers, my_index) + end + end + end +end + +local settings = { + ui = { + border = "none", + icons = { + package_installed = "◍", + package_pending = "◍", + package_uninstalled = "◍", + }, + }, + log_level = vim.log.levels.INFO, + max_concurrent_installers = 4, +} + +require("mason").setup(settings) +-- * buka remark ini jika akan menggunakan list serverrs diatas dan remark config dibawah +-- require("mason-lspconfig").setup({ +-- ensure_installed = servers, +-- automatic_installation = true, +-- }) +-- +-- * buka remark ini jika ingin menjalankan dengan cara install dan remark config diatas (pilih satu) +require("mason-lspconfig").setup() + +local lspconfig_status_ok, lspconfig = pcall(require, "lspconfig") +if not lspconfig_status_ok then + return +end + +local opts = {} + +for _, server in pairs(servers) do + opts = { + on_attach = require("user.lsp.handlers").on_attach, + capabilities = require("user.lsp.handlers").capabilities, + } + + server = vim.split(server, "@")[1] + + local require_ok, conf_opts = pcall(require, "user.lsp.settings." .. server) + if require_ok then + opts = vim.tbl_deep_extend("force", conf_opts, opts) + end + + lspconfig[server].setup(opts) +end