| 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
 | local M = {}
local null_ls = require "null-ls"
local services = require "lsp.null-ls.services"
local Log = require "core.log"
function M.list_supported_names(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 = {}
  for _, provider in pairs(null_ls.builtins.diagnostics) do
    -- TODO: Add support for wildcard filetypes
    if vim.tbl_contains(provider.filetypes or {}, filetype) then
      table.insert(linters, provider.name)
    end
  end
  return linters
end
function M.list_configured(linter_configs, filetype)
  local linters, errors = {}, {}
  for _, lnt_config in pairs(linter_configs) do
    local linter = null_ls.builtins.diagnostics[lnt_config.exe]
    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 = { filetype },
        }
      end
    end
  end
  return { supported = linters, unsupported = errors }
end
function M.setup(linter_configs, filetype)
  if vim.tbl_isempty(linter_configs) then
    return
  end
  local linters_by_ft = M.list_configured(linter_configs, filetype)
  null_ls.register { sources = linters_by_ft.supported }
end
return M
 |