mirror of
https://github.com/NotAShelf/nvf.git
synced 2025-09-07 19:01:35 +00:00
Merge pull request #821 from rice-cracker-dev/lint-required-files
Some checks are pending
Set up binary cache / cachix (default) (push) Waiting to run
Set up binary cache / cachix (maximal) (push) Waiting to run
Set up binary cache / cachix (nix) (push) Waiting to run
Treewide Checks / Validate flake (push) Waiting to run
Treewide Checks / Check formatting (push) Waiting to run
Treewide Checks / Check source tree for typos (push) Waiting to run
Treewide Checks / Validate documentation builds (push) Waiting to run
Treewide Checks / Validate hyperlinks in documentation sources (push) Waiting to run
Treewide Checks / Validate Editorconfig conformance (push) Waiting to run
Build and deploy documentation / Check latest commit (push) Waiting to run
Build and deploy documentation / publish (push) Blocked by required conditions
Some checks are pending
Set up binary cache / cachix (default) (push) Waiting to run
Set up binary cache / cachix (maximal) (push) Waiting to run
Set up binary cache / cachix (nix) (push) Waiting to run
Treewide Checks / Validate flake (push) Waiting to run
Treewide Checks / Check formatting (push) Waiting to run
Treewide Checks / Check source tree for typos (push) Waiting to run
Treewide Checks / Validate documentation builds (push) Waiting to run
Treewide Checks / Validate hyperlinks in documentation sources (push) Waiting to run
Treewide Checks / Validate Editorconfig conformance (push) Waiting to run
Build and deploy documentation / Check latest commit (push) Waiting to run
Build and deploy documentation / publish (push) Blocked by required conditions
nvim-lint: added required files support
This commit is contained in:
commit
92812036cc
6 changed files with 114 additions and 70 deletions
|
@ -289,7 +289,9 @@
|
||||||
[rice-cracker-dev](https://github.com/rice-cracker-dev):
|
[rice-cracker-dev](https://github.com/rice-cracker-dev):
|
||||||
|
|
||||||
- `eslint_d` now checks for configuration files to load.
|
- `eslint_d` now checks for configuration files to load.
|
||||||
- Fixed an error where `eslint_d` fails to load.
|
- Fix an error where `eslint_d` fails to load.
|
||||||
|
- Add required files support for linters under `vim.diagnostics.nvim-lint.linters.*.required_files`.
|
||||||
|
- Add global function `nvf_lint` under `vim.diagnostics.nvim-lint.lint_function`.
|
||||||
|
|
||||||
[Sc3l3t0n](https://github.com/Sc3l3t0n):
|
[Sc3l3t0n](https://github.com/Sc3l3t0n):
|
||||||
|
|
||||||
|
|
|
@ -28,6 +28,8 @@ in {
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
nvf_lint = ${toLuaObject cfg.lint_function}
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
})
|
})
|
||||||
|
@ -38,8 +40,8 @@ in {
|
||||||
{
|
{
|
||||||
event = ["BufWritePost"];
|
event = ["BufWritePost"];
|
||||||
callback = mkLuaInline ''
|
callback = mkLuaInline ''
|
||||||
function()
|
function(args)
|
||||||
require("lint").try_lint()
|
nvf_lint(args.buf)
|
||||||
end
|
end
|
||||||
'';
|
'';
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,8 @@
|
||||||
{lib, ...}: let
|
{lib, ...}: let
|
||||||
inherit (lib.options) mkOption mkEnableOption;
|
inherit (lib.options) mkOption mkEnableOption literalExpression;
|
||||||
inherit (lib.types) nullOr attrsOf listOf str either submodule bool enum;
|
inherit (lib.types) nullOr attrsOf listOf str either submodule bool enum;
|
||||||
inherit (lib.nvim.types) luaInline;
|
inherit (lib.nvim.types) luaInline;
|
||||||
|
inherit (lib.generators) mkLuaInline;
|
||||||
|
|
||||||
linterType = submodule {
|
linterType = submodule {
|
||||||
options = {
|
options = {
|
||||||
|
@ -69,6 +70,23 @@
|
||||||
default = null;
|
default = null;
|
||||||
description = "Parser function";
|
description = "Parser function";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
required_files = mkOption {
|
||||||
|
type = nullOr (listOf str);
|
||||||
|
default = null;
|
||||||
|
example = ["eslint.config.js"];
|
||||||
|
description = ''
|
||||||
|
Required files to lint. These files must exist relative to the cwd
|
||||||
|
of the linter or else this linter will be skipped
|
||||||
|
|
||||||
|
::: {.note}
|
||||||
|
This option is an nvf extension that only takes effect if you
|
||||||
|
use the `nvf_lint()` lua function.
|
||||||
|
|
||||||
|
See {option}`vim.diagnostics.nvim-lint.lint_function`.
|
||||||
|
:::
|
||||||
|
'';
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
in {
|
in {
|
||||||
|
@ -117,5 +135,53 @@ in {
|
||||||
};
|
};
|
||||||
|
|
||||||
lint_after_save = mkEnableOption "autocmd to lint after each save" // {default = true;};
|
lint_after_save = mkEnableOption "autocmd to lint after each save" // {default = true;};
|
||||||
|
|
||||||
|
lint_function = mkOption {
|
||||||
|
type = luaInline;
|
||||||
|
default = mkLuaInline ''
|
||||||
|
function(buf)
|
||||||
|
local ft = vim.api.nvim_get_option_value("filetype", { buf = buf })
|
||||||
|
local linters = require("lint").linters
|
||||||
|
local linters_from_ft = require("lint").linters_by_ft[ft]
|
||||||
|
|
||||||
|
-- if no linter is configured for this filetype, stops linting
|
||||||
|
if linters_from_ft == nil then return end
|
||||||
|
|
||||||
|
for _, name in ipairs(linters_from_ft) do
|
||||||
|
local linter = linters[name]
|
||||||
|
assert(linter, 'Linter with name `' .. name .. '` not available')
|
||||||
|
|
||||||
|
if type(linter) == "function" then
|
||||||
|
linter = linter()
|
||||||
|
end
|
||||||
|
-- for require("lint").lint() to work, linter.name must be set
|
||||||
|
linter.name = linter.name or name
|
||||||
|
local cwd = linter.required_files
|
||||||
|
|
||||||
|
-- if no configuration files are configured, lint
|
||||||
|
if cwd == nil then
|
||||||
|
require("lint").lint(linter)
|
||||||
|
else
|
||||||
|
-- if configuration files are configured and present in the project, lint
|
||||||
|
for _, fn in ipairs(cwd) do
|
||||||
|
local path = vim.fs.joinpath(linter.cwd or vim.fn.getcwd(), fn);
|
||||||
|
if vim.uv.fs_stat(path) then
|
||||||
|
require("lint").lint(linter)
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
'';
|
||||||
|
example = literalExpression ''
|
||||||
|
mkLuaInline '''
|
||||||
|
function(buf)
|
||||||
|
require("lint").try_lint()
|
||||||
|
end
|
||||||
|
'''
|
||||||
|
'';
|
||||||
|
description = "Define the global function nvf_lint which is used by nvf to lint.";
|
||||||
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -53,24 +53,20 @@
|
||||||
# TODO: specify packages
|
# TODO: specify packages
|
||||||
defaultDiagnosticsProvider = ["eslint_d"];
|
defaultDiagnosticsProvider = ["eslint_d"];
|
||||||
diagnosticsProviders = {
|
diagnosticsProviders = {
|
||||||
eslint_d = {
|
eslint_d = let
|
||||||
package = pkgs.eslint_d;
|
pkg = pkgs.eslint_d;
|
||||||
|
in {
|
||||||
|
package = pkg;
|
||||||
config = {
|
config = {
|
||||||
# HACK: change if nvim-lint gets a dynamic enable thing
|
cmd = getExe pkg;
|
||||||
parser = mkLuaInline ''
|
required_files = [
|
||||||
function(output, bufnr, cwd)
|
"eslint.config.js"
|
||||||
local markers = { "eslint.config.js", "eslint.config.mjs",
|
"eslint.config.mjs"
|
||||||
".eslintrc", ".eslintrc.json", ".eslintrc.js", ".eslintrc.yml", }
|
".eslintrc"
|
||||||
for _, filename in ipairs(markers) do
|
".eslintrc.json"
|
||||||
local path = vim.fs.joinpath(cwd, filename)
|
".eslintrc.js"
|
||||||
if vim.loop.fs_stat(path) then
|
".eslintrc.yml"
|
||||||
return require("lint.linters.eslint_d").parser(output, bufnr, cwd)
|
];
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
return {}
|
|
||||||
end
|
|
||||||
'';
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -153,16 +149,9 @@ in {
|
||||||
vim.diagnostics.nvim-lint = {
|
vim.diagnostics.nvim-lint = {
|
||||||
enable = true;
|
enable = true;
|
||||||
linters_by_ft.astro = cfg.extraDiagnostics.types;
|
linters_by_ft.astro = cfg.extraDiagnostics.types;
|
||||||
linters = mkMerge (map (
|
linters =
|
||||||
name: {
|
mkMerge (map (name: {${name} = diagnosticsProviders.${name}.config;})
|
||||||
${name} =
|
cfg.extraDiagnostics.types);
|
||||||
diagnosticsProviders.${name}.config
|
|
||||||
// {
|
|
||||||
cmd = getExe diagnosticsProviders.${name}.package;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
)
|
|
||||||
cfg.extraDiagnostics.types);
|
|
||||||
};
|
};
|
||||||
})
|
})
|
||||||
]);
|
]);
|
||||||
|
|
|
@ -55,21 +55,14 @@
|
||||||
package = pkg;
|
package = pkg;
|
||||||
config = {
|
config = {
|
||||||
cmd = getExe pkg;
|
cmd = getExe pkg;
|
||||||
# HACK: change if nvim-lint gets a dynamic enable thing
|
required_files = [
|
||||||
parser = mkLuaInline ''
|
"eslint.config.js"
|
||||||
function(output, bufnr, cwd)
|
"eslint.config.mjs"
|
||||||
local markers = { "eslint.config.js", "eslint.config.mjs",
|
".eslintrc"
|
||||||
".eslintrc", ".eslintrc.json", ".eslintrc.js", ".eslintrc.yml", }
|
".eslintrc.json"
|
||||||
for _, filename in ipairs(markers) do
|
".eslintrc.js"
|
||||||
local path = vim.fs.joinpath(cwd, filename)
|
".eslintrc.yml"
|
||||||
if vim.loop.fs_stat(path) then
|
];
|
||||||
return require("lint.linters.eslint_d").parser(output, bufnr, cwd)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
return {}
|
|
||||||
end
|
|
||||||
'';
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
|
@ -91,27 +91,20 @@
|
||||||
# TODO: specify packages
|
# TODO: specify packages
|
||||||
defaultDiagnosticsProvider = ["eslint_d"];
|
defaultDiagnosticsProvider = ["eslint_d"];
|
||||||
diagnosticsProviders = {
|
diagnosticsProviders = {
|
||||||
eslint_d = {
|
eslint_d = let
|
||||||
package = pkgs.eslint_d;
|
pkg = pkgs.eslint_d;
|
||||||
config = let
|
in {
|
||||||
pkg = pkgs.eslint_d;
|
package = pkg;
|
||||||
in {
|
config = {
|
||||||
cmd = getExe pkg;
|
cmd = getExe pkg;
|
||||||
# HACK: change if nvim-lint gets a dynamic enable thing
|
required_files = [
|
||||||
parser = mkLuaInline ''
|
"eslint.config.js"
|
||||||
function(output, bufnr, cwd)
|
"eslint.config.mjs"
|
||||||
local markers = { "eslint.config.js", "eslint.config.mjs",
|
".eslintrc"
|
||||||
".eslintrc", ".eslintrc.json", ".eslintrc.js", ".eslintrc.yml", }
|
".eslintrc.json"
|
||||||
for _, filename in ipairs(markers) do
|
".eslintrc.js"
|
||||||
local path = vim.fs.joinpath(cwd, filename)
|
".eslintrc.yml"
|
||||||
if vim.loop.fs_stat(path) then
|
];
|
||||||
return require("lint.linters.eslint_d").parser(output, bufnr, cwd)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
return {}
|
|
||||||
end
|
|
||||||
'';
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -221,10 +214,9 @@ in {
|
||||||
linters_by_ft.typescript = cfg.extraDiagnostics.types;
|
linters_by_ft.typescript = cfg.extraDiagnostics.types;
|
||||||
linters_by_ft.typescriptreact = cfg.extraDiagnostics.types;
|
linters_by_ft.typescriptreact = cfg.extraDiagnostics.types;
|
||||||
|
|
||||||
linters = mkMerge (map (name: {
|
linters =
|
||||||
${name}.cmd = getExe diagnosticsProviders.${name}.package;
|
mkMerge (map (name: {${name} = diagnosticsProviders.${name}.config;})
|
||||||
})
|
cfg.extraDiagnostics.types);
|
||||||
cfg.extraDiagnostics.types);
|
|
||||||
};
|
};
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue