diff options
author | kylo252 <[email protected]> | 2022-01-06 11:37:49 +0100 |
---|---|---|
committer | GitHub <[email protected]> | 2022-01-06 11:37:49 +0100 |
commit | 8fd71b50847addb160d58c2045ced8d6f6c6e0ef (patch) | |
tree | ca565af19b46f0f0c1ffba391ac1393b2fb19c84 /lua/lvim/lsp/null-ls/linters.lua | |
parent | b10e18a213741dcd4ce1e7ba63accaf10719dbec (diff) |
refactor(null-ls): allow passing full list of options for sources (#2137)
Diffstat (limited to 'lua/lvim/lsp/null-ls/linters.lua')
-rw-r--r-- | lua/lvim/lsp/null-ls/linters.lua | 57 |
1 files changed, 9 insertions, 48 deletions
diff --git a/lua/lvim/lsp/null-ls/linters.lua b/lua/lvim/lsp/null-ls/linters.lua index 67e530a9..07c8094b 100644 --- a/lua/lvim/lsp/null-ls/linters.lua +++ b/lua/lvim/lsp/null-ls/linters.lua @@ -1,22 +1,14 @@ local M = {} -local null_ls = require "null-ls" -local services = require "lvim.lsp.null-ls.services" local Log = require "lvim.core.log" -local is_registered = function(name) - local query = { - name = name, - method = require("null-ls").methods.DIAGNOSTICS, - } - return require("null-ls.sources").is_registered(query) -end +local null_ls = require "null-ls" +local services = require "lvim.lsp.null-ls.services" +local method = null_ls.methods.DIAGNOSTICS function M.list_registered(filetype) - local null_ls_methods = require "null-ls.methods" - local linter_method = null_ls_methods.internal["DIAGNOSTICS"] local registered_providers = services.list_registered_providers_names(filetype) - return registered_providers[linter_method] or {} + return registered_providers[method] or {} end function M.list_supported(filetype) @@ -26,47 +18,16 @@ function M.list_supported(filetype) return supported_linters end -function M.list_configured(linter_configs) - local linters, errors = {}, {} - - for _, lnt_config in pairs(linter_configs) do - local name = lnt_config.exe:gsub("-", "_") - local linter = null_ls.builtins.diagnostics[name] - - if not linter then - Log:error("Not a valid linter: " .. lnt_config.exe) - errors[lnt_config.exe] = {} -- Add data here when necessary - elseif is_registered(lnt_config.exe) then - Log:trace "Skipping registering the source more than once" - else - local linter_cmd = services.find_command(linter._opts.command) - if not linter_cmd then - Log:warn("Not found: " .. linter._opts.command) - errors[name] = {} -- Add data here when necessary - else - Log:debug("Using linter: " .. linter_cmd) - table.insert( - linters, - linter.with { - command = linter_cmd, - extra_args = lnt_config.args, - filetypes = lnt_config.filetypes, - } - ) - end - end - end - - return { supported = linters, unsupported = errors } -end - function M.setup(linter_configs) if vim.tbl_isempty(linter_configs) then return end - local linters = M.list_configured(linter_configs) - null_ls.register { sources = linters.supported } + local registered = services.register_sources(linter_configs, method) + + if #registered > 0 then + Log:debug("Registered the following linters: " .. unpack(registered)) + end end return M |