summaryrefslogtreecommitdiff
path: root/lua/lvim/lsp/null-ls/linters.lua
diff options
context:
space:
mode:
authorkylo252 <[email protected]>2022-01-06 11:37:49 +0100
committerGitHub <[email protected]>2022-01-06 11:37:49 +0100
commit8fd71b50847addb160d58c2045ced8d6f6c6e0ef (patch)
treeca565af19b46f0f0c1ffba391ac1393b2fb19c84 /lua/lvim/lsp/null-ls/linters.lua
parentb10e18a213741dcd4ce1e7ba63accaf10719dbec (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.lua57
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