diff options
author | kylo252 <[email protected]> | 2021-08-01 12:02:10 +0200 |
---|---|---|
committer | GitHub <[email protected]> | 2021-08-01 10:02:10 +0000 |
commit | e2dd993ce753f8d28e6c32c4697ba51cc8ace2bb (patch) | |
tree | 2954bfc726f858d2efb4f18d6c2b193305c2494b /lua/lsp/null-ls.lua | |
parent | 30ad4b81f5dbccb6d49eb28ffdd33cefcb758ee5 (diff) |
refactor null-ls (#1202)
Diffstat (limited to 'lua/lsp/null-ls.lua')
-rw-r--r-- | lua/lsp/null-ls.lua | 67 |
1 files changed, 32 insertions, 35 deletions
diff --git a/lua/lsp/null-ls.lua b/lua/lsp/null-ls.lua index b8f9bfe6..51fab00b 100644 --- a/lua/lsp/null-ls.lua +++ b/lua/lsp/null-ls.lua @@ -23,40 +23,37 @@ function M.get_registered_providers_by_filetype(ft) return matches end -local function is_nodejs_provider(provider) - for _, local_provider in ipairs(nodejs_local_providers) do - if local_provider == provider._opts.command then - return true - end +local function validate_nodejs_provider(requests, provider) + vim.cmd "let root_dir = FindRootDirectory()" + local root_dir = vim.api.nvim_get_var "root_dir" + local local_nodejs_command = root_dir .. "/node_modules/.bin/" .. provider._opts.command + u.lvim_log(string.format("checking for local node module: [%s]", vim.inspect(provider))) + if vim.fn.executable(local_nodejs_command) == 1 then + provider._opts.command = local_nodejs_command + table.insert(requests, provider) + elseif vim.fn.executable(provider._opts.command) == 1 then + u.lvim_log(string.format("checking in global path instead for node module: [%s]", provider._opts.command)) + table.insert(requests, provider) + else + u.lvim_log(string.format("Unable to find node module: [%s]", provider._opts.command)) + return false end - return false + return true end -local function is_provider_found(provider) - local retval = { is_local = false, path = nil } - if is_nodejs_provider(provider) then - vim.cmd "let root_dir = FindRootDirectory()" - local root_dir = vim.api.nvim_get_var "root_dir" - local local_provider_command = root_dir .. "/node_modules/.bin/" .. provider._opts.command - if vim.fn.executable(local_provider_command) == 1 then - return true, local_provider_command - end +local function validate_provider_request(requests, provider) + if provider == "" or provider == nil then + return false end - if vim.fn.executable(provider._opts.command) == 1 then - return false, provider._opts.command + -- NOTE: we can't use provider.name because eslint_d uses eslint name + if vim.tbl_contains(nodejs_local_providers, provider._opts.command) then + return validate_nodejs_provider(requests, provider) end - return retval.is_local, retval.path -end - -local function validate_provider(provider) - local is_local, provider_path = is_provider_found(provider) - if not provider_path then + if vim.fn.executable(provider._opts.command) ~= 1 then u.lvim_log(string.format("Unable to find the path for: [%s]", vim.inspect(provider))) return false end - if is_local then - provider._opts.command = provider_path - end + table.insert(requests, provider) return true end @@ -67,25 +64,25 @@ function M.setup(filetype) -- FIXME: why doesn't this work? -- builtin_formatter._opts.args = formatter.args or builtin_formatter._opts.args -- builtin_formatter._opts.to_stdin = formatter.stdin or builtin_formatter._opts.to_stdin - table.insert(M.requested_providers, builtin_formatter) - u.lvim_log(string.format("Using format provider: [%s]", formatter.exe)) + if validate_provider_request(M.requested_providers, builtin_formatter) then + u.lvim_log(string.format("Using format provider: [%s]", formatter.exe)) + end end for _, linter in pairs(lvim.lang[filetype].linters) do local builtin_diagnoser = null_ls.builtins.diagnostics[linter.exe] - -- FIXME: why doesn't this work? - -- builtin_diagnoser._opts.args = linter.args or builtin_diagnoser._opts.args - -- builtin_diagnoser._opts.to_stdin = linter.stdin or builtin_diagnoser._opts.to_stdin - -- NOTE: validate before inserting to table -- special case: fallback to "eslint" -- https://github.com/jose-elias-alvarez/null-ls.nvim/blob/9b8458bd1648e84169a7e8638091ba15c2f20fc0/doc/BUILTINS.md#eslint + -- if provider.exe if linter.exe == "eslint_d" then builtin_diagnoser = null_ls.builtins.diagnostics.eslint.with { command = "eslint_d" } end - if validate_provider(builtin_diagnoser) then - table.insert(M.requested_providers, builtin_diagnoser) + -- FIXME: why doesn't this work? + -- builtin_diagnoser._opts.args = linter.args or builtin_diagnoser._opts.args + -- builtin_diagnoser._opts.to_stdin = linter.stdin or builtin_diagnoser._opts.to_stdin + if validate_provider_request(M.requested_providers, builtin_diagnoser) then + u.lvim_log(string.format("Using linter provider: [%s]", linter.exe)) end - u.lvim_log(string.format("Using linter provider: [%s]", linter.exe)) end null_ls.register { sources = M.requested_providers } |