blob: 85555bae4d584206a968ba19cadcd943349f13db (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
|
local M = {}
local null_ls = require "null-ls"
local services = require "lsp.null-ls.services"
local Log = require "core.log"
function M.list_registered_providers(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 {}
end
function M.list_available(filetype)
local linters = {}
local tbl = require "utils.table"
for _, provider in pairs(null_ls.builtins.diagnostics) do
if
tbl.contains(provider.filetypes or {}, function(ft)
return ft == "*" or ft == filetype
end)
then
table.insert(linters, provider.name)
end
end
table.sort(linters)
return linters
end
function M.list_configured(linter_configs)
local linters, errors = {}, {}
for _, lnt_config in pairs(linter_configs) do
local linter_name = lnt_config.exe:gsub("-", "_")
local linter = null_ls.builtins.diagnostics[linter_name]
if not linter then
Log:error("Not a valid linter: " .. lnt_config.exe)
errors[lnt_config.exe] = {} -- Add data here when necessary
else
local linter_cmd = services.find_command(linter._opts.command)
if not linter_cmd then
Log:warn("Not found: " .. linter._opts.command)
errors[lnt_config.exe] = {} -- Add data here when necessary
else
Log:debug("Using linter: " .. linter_cmd)
linters[lnt_config.exe] = 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 }
end
return M
|