mirror of
https://github.com/nix-community/nixvim.git
synced 2025-06-23 09:18:38 +02:00
plugins/coverage: init + test
This commit is contained in:
parent
9324c825b9
commit
58ccb99e2d
3 changed files with 406 additions and 0 deletions
319
plugins/utils/coverage.nix
Normal file
319
plugins/utils/coverage.nix
Normal file
|
@ -0,0 +1,319 @@
|
|||
{
|
||||
pkgs,
|
||||
config,
|
||||
lib,
|
||||
...
|
||||
}:
|
||||
with lib; let
|
||||
cfg = config.plugins.coverage;
|
||||
helpers = import ../helpers.nix {inherit lib;};
|
||||
|
||||
keymapsDef = {
|
||||
coverage = {
|
||||
command = "";
|
||||
description = "Loads a coverage report and immediately displays the coverage signs.";
|
||||
};
|
||||
load = {
|
||||
command = "Load";
|
||||
description = "Loads a coverage report but does not display the coverage signs.";
|
||||
};
|
||||
show = {
|
||||
command = "Show";
|
||||
description = ''
|
||||
Shows the coverage signs.
|
||||
Must call `:Coverage` or `:CoverageLoad` first.
|
||||
'';
|
||||
};
|
||||
hide = {
|
||||
command = "Hide";
|
||||
description = ''
|
||||
Hides the coverage signs.
|
||||
Must call `:Coverage` or `:CoverageLoad` first.
|
||||
'';
|
||||
};
|
||||
toggle = {
|
||||
command = "Toggle";
|
||||
description = ''
|
||||
Toggles the coverage signs.
|
||||
Must call `:Coverage` or `:CoverageLoad` first.
|
||||
'';
|
||||
};
|
||||
clear = {
|
||||
command = "Clear";
|
||||
description = ''
|
||||
Unloads the cached coverage signs.
|
||||
`:Coverage` or `:CoverageLoad` must be called again to relad the data.
|
||||
'';
|
||||
};
|
||||
summary = {
|
||||
command = "Summary";
|
||||
description = "Displays a coverage summary report in a floating window.";
|
||||
};
|
||||
};
|
||||
in {
|
||||
options.plugins.coverage =
|
||||
helpers.extraOptionsOptions
|
||||
// {
|
||||
enable = mkEnableOption "nvim-coverage";
|
||||
|
||||
package = helpers.mkPackageOption "nvim-coverage" pkgs.vimPlugins.nvim-coverage;
|
||||
|
||||
keymapsSilent = mkOption {
|
||||
type = types.bool;
|
||||
description = "Whether nvim-coverage keymaps should be silent";
|
||||
default = false;
|
||||
};
|
||||
|
||||
keymaps =
|
||||
mapAttrs
|
||||
(
|
||||
optionName: properties:
|
||||
helpers.mkNullOrOption types.str properties.description
|
||||
)
|
||||
keymapsDef;
|
||||
|
||||
autoReload = helpers.defaultNullOpts.mkBool false ''
|
||||
If true, the `coverage_file` for a langauge will be watched for changes after executing
|
||||
`:CoverageLoad` or `coverage.load()`.
|
||||
The file watcher will be stopped after executing `:CoverageClear` or `coverage.clear()`.
|
||||
'';
|
||||
|
||||
autoReloadTimeoutMs = helpers.defaultNullOpts.mkInt 500 ''
|
||||
The number of milliseconds to wait before auto-reloading coverage after detecting a change.
|
||||
'';
|
||||
|
||||
commands = helpers.defaultNullOpts.mkBool true "If true, create commands.";
|
||||
|
||||
highlights = {
|
||||
covered =
|
||||
helpers.defaultNullOpts.mkNullable
|
||||
types.attrs
|
||||
''{fg = "#B7F071";}''
|
||||
"Highlight group for covered signs.";
|
||||
|
||||
uncovered =
|
||||
helpers.defaultNullOpts.mkNullable
|
||||
types.attrs
|
||||
''{fg = "#F07178";}''
|
||||
"Highlight group for uncovered signs.";
|
||||
|
||||
partial =
|
||||
helpers.defaultNullOpts.mkNullable
|
||||
types.attrs
|
||||
''{fg = "#AA71F0";}''
|
||||
"Highlight group for partial coverage signs.";
|
||||
|
||||
summaryBorder =
|
||||
helpers.defaultNullOpts.mkNullable
|
||||
types.attrs
|
||||
''{link = "FloatBorder";}''
|
||||
"Border highlight group of the summary pop-up.";
|
||||
|
||||
summaryNormal =
|
||||
helpers.defaultNullOpts.mkNullable
|
||||
types.attrs
|
||||
''{link = "NormalFloat";}''
|
||||
"Normal text highlight group of the summary pop-up.";
|
||||
|
||||
summaryCursorLine =
|
||||
helpers.defaultNullOpts.mkNullable
|
||||
types.attrs
|
||||
''{link = "CursorLine";}''
|
||||
"Cursor line highlight group of the summary pop-up.";
|
||||
|
||||
summaryHeader =
|
||||
helpers.defaultNullOpts.mkNullable
|
||||
types.attrs
|
||||
''{ style = "bold,underline"; sp = "bg"; }''
|
||||
"Header text highlight group of the summary pop-up.";
|
||||
|
||||
summaryPass =
|
||||
helpers.defaultNullOpts.mkNullable
|
||||
types.attrs
|
||||
''{link = "CoverageCovered";}''
|
||||
"Pass text highlight group of the summary pop-up.";
|
||||
|
||||
summaryFail =
|
||||
helpers.defaultNullOpts.mkNullable
|
||||
types.attrs
|
||||
''{link = "CoverageUncovered";}''
|
||||
"Fail text highlight group of the summary pop-up.";
|
||||
};
|
||||
|
||||
loadCoverageCb = helpers.mkNullOrOption types.str ''
|
||||
A lua function that will be called when a coverage file is loaded.
|
||||
|
||||
Example:
|
||||
```
|
||||
function (ftype)
|
||||
vim.notify("Loaded " .. ftype .. " coverage")
|
||||
end
|
||||
```
|
||||
'';
|
||||
|
||||
signs =
|
||||
mapAttrs
|
||||
(
|
||||
optionName: {
|
||||
prettyName ? optionName,
|
||||
defaults,
|
||||
}: {
|
||||
hl =
|
||||
helpers.defaultNullOpts.mkStr
|
||||
defaults.hl
|
||||
"The highlight group used for ${prettyName} signs.";
|
||||
|
||||
text =
|
||||
helpers.defaultNullOpts.mkStr
|
||||
defaults.text
|
||||
"The text used for ${prettyName} signs.";
|
||||
}
|
||||
)
|
||||
{
|
||||
covered = {
|
||||
defaults = {
|
||||
hl = "CoverageCovered";
|
||||
text = "▎";
|
||||
};
|
||||
};
|
||||
uncovered = {
|
||||
defaults = {
|
||||
hl = "CoverageUncovered";
|
||||
text = "▎";
|
||||
};
|
||||
};
|
||||
partial = {
|
||||
prettyName = "partial coverage";
|
||||
defaults = {
|
||||
hl = "CoveragePartial";
|
||||
text = "▎";
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
signGroup = helpers.defaultNullOpts.mkStr "coverage" ''
|
||||
Name of the sign group used when placing the signs.
|
||||
See `:h sign-group`.
|
||||
'';
|
||||
|
||||
summary = {
|
||||
widthPercentage =
|
||||
helpers.defaultNullOpts.mkNullable
|
||||
(types.numbers.between 0.0 1.0)
|
||||
"0.70"
|
||||
"Width of the pop-up window.";
|
||||
|
||||
heightPercentage =
|
||||
helpers.defaultNullOpts.mkNullable
|
||||
(types.numbers.between 0.0 1.0)
|
||||
"0.50"
|
||||
"Height of the pop-up window.";
|
||||
|
||||
borders =
|
||||
mapAttrs
|
||||
(
|
||||
optionName: default:
|
||||
helpers.defaultNullOpts.mkStr default ""
|
||||
)
|
||||
{
|
||||
topleft = "╭";
|
||||
topright = "╮";
|
||||
top = "─";
|
||||
left = "│";
|
||||
right = "│";
|
||||
botleft = "╰";
|
||||
botright = "╯";
|
||||
bot = "─";
|
||||
highlight = "Normal:CoverageSummaryBorder";
|
||||
};
|
||||
|
||||
minCoverage =
|
||||
helpers.defaultNullOpts.mkNullable
|
||||
(types.numbers.between 0 100)
|
||||
"80"
|
||||
''
|
||||
Minimum coverage percentage.
|
||||
Values below this are highlighted with the fail group, values above are highlighted with
|
||||
the pass group.
|
||||
'';
|
||||
};
|
||||
|
||||
lang = helpers.defaultNullOpts.mkNullable types.attrs "see upstream documentation" ''
|
||||
Each key corresponds with the `filetype` of the language and maps to an attrs of
|
||||
configuration values that differ.
|
||||
See plugin documentation for language specific options.
|
||||
|
||||
Example:
|
||||
```
|
||||
{
|
||||
python = {
|
||||
coverage_file = ".coverage";
|
||||
coverage_command = "coverage json --fail-under=0 -q -o -";
|
||||
};
|
||||
ruby = {
|
||||
coverage_file = "coverage/coverage.json";
|
||||
};
|
||||
}
|
||||
```
|
||||
'';
|
||||
|
||||
lcovFile =
|
||||
helpers.mkNullOrOption
|
||||
types.str
|
||||
"File that the plugin will try to read lcov coverage from.";
|
||||
};
|
||||
|
||||
config = let
|
||||
setupOptions = with cfg;
|
||||
{
|
||||
auto_reload = autoReload;
|
||||
auto_reload_timeout_ms = autoReloadTimeoutMs;
|
||||
inherit commands;
|
||||
highlights = with highlights; {
|
||||
inherit covered uncovered partial;
|
||||
summary_border = summaryBorder;
|
||||
summary_normal = summaryNormal;
|
||||
summary_cursor_line = summaryCursorLine;
|
||||
summary_header = summaryHeader;
|
||||
summary_pass = summaryPass;
|
||||
summary_fail = summaryFail;
|
||||
};
|
||||
load_coverage_cb = helpers.ifNonNull' loadCoverageCb (helpers.mkRaw loadCoverageCb);
|
||||
inherit signs;
|
||||
sign_group = signGroup;
|
||||
summary = with summary; {
|
||||
width_percentage = widthPercentage;
|
||||
height_percentage = heightPercentage;
|
||||
inherit borders;
|
||||
min_coverage = minCoverage;
|
||||
};
|
||||
inherit lang;
|
||||
lcov_file = lcovFile;
|
||||
}
|
||||
// cfg.extraOptions;
|
||||
in
|
||||
mkIf cfg.enable {
|
||||
extraPlugins = [cfg.package];
|
||||
|
||||
extraConfigLua = ''
|
||||
require("coverage").setup(${helpers.toLuaObject setupOptions})
|
||||
'';
|
||||
|
||||
maps.normal = mkMerge (
|
||||
mapAttrsToList
|
||||
(
|
||||
optionName: properties: let
|
||||
key = cfg.keymaps.${optionName};
|
||||
in
|
||||
mkIf (key != null)
|
||||
{
|
||||
${key} = {
|
||||
action = ":Coverage${properties.command}<CR>";
|
||||
silent = cfg.keymapsSilent;
|
||||
};
|
||||
}
|
||||
)
|
||||
keymapsDef
|
||||
);
|
||||
};
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue