mirror of
https://github.com/NotAShelf/nvf.git
synced 2025-10-12 11:49:34 +00:00
Merge branch 'main' into main
This commit is contained in:
commit
2c9a8e2857
5 changed files with 103 additions and 24 deletions
1
.github/typos.toml
vendored
1
.github/typos.toml
vendored
|
@ -5,6 +5,7 @@ default.extend-ignore-words-re = [
|
||||||
"befores",
|
"befores",
|
||||||
"annote",
|
"annote",
|
||||||
"viw",
|
"viw",
|
||||||
|
"typ",
|
||||||
"BA", # somehow "BANanaD3V" is valid, but BA is not...
|
"BA", # somehow "BANanaD3V" is valid, but BA is not...
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
|
@ -499,6 +499,14 @@
|
||||||
|
|
||||||
- Add [nvim-highlight-colors] plugin in `vim.ui.nvim-highlight-colors` with
|
- Add [nvim-highlight-colors] plugin in `vim.ui.nvim-highlight-colors` with
|
||||||
`enable` and `setupOpts`
|
`enable` and `setupOpts`
|
||||||
- Fix [blink.cmp] keymap preset types to allow alternate cmdline, terminal,
|
|
||||||
etc modes to `inherit` the default mode keymaps. This is an option as per
|
- Fix [blink.cmp] keymap preset types to allow alternate cmdline, terminal, etc
|
||||||
the [blink.cmp] docs and is now supported in docs and is now supported in nvf.nvf.
|
modes to `inherit` the default mode keymaps. This is an option as per the
|
||||||
|
[blink.cmp] docs and is now supported in nvf.
|
||||||
|
|
||||||
|
[PartyWumpus](https://github.com/PartyWumpus):
|
||||||
|
|
||||||
|
[typst-concealer]: https://github.com/PartyWumpus/typst-concealer
|
||||||
|
|
||||||
|
- Add inline typst concealing support under `vim.languages.typst` using
|
||||||
|
[typst-concealer].
|
||||||
|
|
|
@ -60,7 +60,17 @@
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
nixd = {
|
nixd = let
|
||||||
|
settings.nixd = {
|
||||||
|
inherit (cfg.lsp) options;
|
||||||
|
formatting.command =
|
||||||
|
if !cfg.format.enable
|
||||||
|
then null
|
||||||
|
else if cfg.format.type == "alejandra"
|
||||||
|
then ["${cfg.format.package}/bin/alejandra" "--quiet"]
|
||||||
|
else ["${cfg.format.package}/bin/nixfmt"];
|
||||||
|
};
|
||||||
|
in {
|
||||||
package = pkgs.nixd;
|
package = pkgs.nixd;
|
||||||
internalFormatter = true;
|
internalFormatter = true;
|
||||||
lspConfig = ''
|
lspConfig = ''
|
||||||
|
@ -72,25 +82,7 @@
|
||||||
else noFormat
|
else noFormat
|
||||||
},
|
},
|
||||||
cmd = ${packageToCmd cfg.lsp.package "nixd"},
|
cmd = ${packageToCmd cfg.lsp.package "nixd"},
|
||||||
options = ${toLuaObject cfg.lsp.options},
|
settings = ${toLuaObject settings},
|
||||||
${optionalString cfg.format.enable ''
|
|
||||||
settings = {
|
|
||||||
nixd = {
|
|
||||||
${optionalString (cfg.format.type == "alejandra")
|
|
||||||
''
|
|
||||||
formatting = {
|
|
||||||
command = {"${cfg.format.package}/bin/alejandra", "--quiet"},
|
|
||||||
},
|
|
||||||
''}
|
|
||||||
${optionalString (cfg.format.type == "nixfmt")
|
|
||||||
''
|
|
||||||
formatting = {
|
|
||||||
command = {"${cfg.format.package}/bin/nixfmt"},
|
|
||||||
},
|
|
||||||
''}
|
|
||||||
},
|
|
||||||
},
|
|
||||||
''}
|
|
||||||
}
|
}
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
|
@ -7,9 +7,10 @@
|
||||||
inherit (lib.options) mkEnableOption mkOption;
|
inherit (lib.options) mkEnableOption mkOption;
|
||||||
inherit (lib.modules) mkIf mkMerge;
|
inherit (lib.modules) mkIf mkMerge;
|
||||||
inherit (lib.lists) isList;
|
inherit (lib.lists) isList;
|
||||||
inherit (lib.types) nullOr enum either attrsOf listOf package str;
|
inherit (lib.types) nullOr enum either attrsOf listOf package str bool int;
|
||||||
inherit (lib.attrsets) attrNames;
|
inherit (lib.attrsets) attrNames;
|
||||||
inherit (lib.meta) getExe;
|
inherit (lib.meta) getExe;
|
||||||
|
inherit (lib.nvim.binds) mkMappingOption mkKeymap;
|
||||||
inherit (lib.nvim.lua) expToLua toLuaObject;
|
inherit (lib.nvim.lua) expToLua toLuaObject;
|
||||||
inherit (lib.nvim.types) mkGrammarOption mkPluginSetupOption;
|
inherit (lib.nvim.types) mkGrammarOption mkPluginSetupOption;
|
||||||
inherit (lib.nvim.dag) entryAnywhere;
|
inherit (lib.nvim.dag) entryAnywhere;
|
||||||
|
@ -150,6 +151,57 @@ in {
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
typst-concealer = {
|
||||||
|
enable = mkEnableOption ''
|
||||||
|
[typst-concealer]: https://github.com/PartyWumpus/typst-concealer
|
||||||
|
|
||||||
|
Inline typst preview for Neovim via [typst-concealer]
|
||||||
|
'';
|
||||||
|
|
||||||
|
mappings = {
|
||||||
|
toggleConcealing = mkMappingOption "Enable typst-concealer in buffer" "<leader>TT";
|
||||||
|
};
|
||||||
|
|
||||||
|
setupOpts = mkPluginSetupOption "typst-concealer" {
|
||||||
|
do_diagnostics = mkOption {
|
||||||
|
type = nullOr bool;
|
||||||
|
default = !cfg.lsp.enable;
|
||||||
|
description = "Should typst-concealer provide diagnostics on error?";
|
||||||
|
};
|
||||||
|
color = mkOption {
|
||||||
|
type = nullOr str;
|
||||||
|
default = null;
|
||||||
|
example = "rgb(\"#f012be\")";
|
||||||
|
description = "What color should typst-concealer render text/stroke with? (only applies when styling_type is 'colorscheme')";
|
||||||
|
};
|
||||||
|
enabled_by_default = mkOption {
|
||||||
|
type = nullOr bool;
|
||||||
|
default = null;
|
||||||
|
description = "Should typst-concealer conceal newly opened buffers by default?";
|
||||||
|
};
|
||||||
|
styling_type = mkOption {
|
||||||
|
type = nullOr (enum ["simple" "none" "colorscheme"]);
|
||||||
|
default = null;
|
||||||
|
description = "What kind of styling should typst-concealer apply to your typst?";
|
||||||
|
};
|
||||||
|
ppi = mkOption {
|
||||||
|
type = nullOr int;
|
||||||
|
default = null;
|
||||||
|
description = "What PPI should typst render at. Plugin default is 300, typst's normal default is 144.";
|
||||||
|
};
|
||||||
|
typst_location = mkOption {
|
||||||
|
type = str;
|
||||||
|
default = getExe pkgs.typst;
|
||||||
|
description = "Where should typst-concealer look for your typst binary?";
|
||||||
|
example = ''lib.getExe pkgs.typst'';
|
||||||
|
};
|
||||||
|
conceal_in_normal = mkOption {
|
||||||
|
type = nullOr bool;
|
||||||
|
default = null;
|
||||||
|
description = "Should typst-concealer still conceal when the normal mode cursor goes over a line.";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
config = mkIf cfg.enable (mkMerge [
|
config = mkIf cfg.enable (mkMerge [
|
||||||
|
@ -180,5 +232,18 @@ in {
|
||||||
require("typst-preview").setup(${toLuaObject cfg.extensions.typst-preview-nvim.setupOpts})
|
require("typst-preview").setup(${toLuaObject cfg.extensions.typst-preview-nvim.setupOpts})
|
||||||
'';
|
'';
|
||||||
})
|
})
|
||||||
|
|
||||||
|
(mkIf cfg.extensions.typst-concealer.enable {
|
||||||
|
vim.lazy.plugins.typst-concealer = {
|
||||||
|
event = "BufRead *.typ";
|
||||||
|
package = "typst-concealer";
|
||||||
|
setupModule = "typst-concealer";
|
||||||
|
setupOpts = cfg.extensions.typst-concealer.setupOpts;
|
||||||
|
|
||||||
|
keys = [
|
||||||
|
(mkKeymap "n" cfg.extensions.typst-concealer.mappings.toggleConcealing "<cmd>lua require('typst-concealer').toggle_buf()<CR>" {desc = "Toggle typst-concealer in buffer";})
|
||||||
|
];
|
||||||
|
};
|
||||||
|
})
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
|
@ -2526,6 +2526,19 @@
|
||||||
"url": "https://github.com/dmmulroy/ts-error-translator.nvim/archive/47e5ba89f71b9e6c72eaaaaa519dd59bd6897df4.tar.gz",
|
"url": "https://github.com/dmmulroy/ts-error-translator.nvim/archive/47e5ba89f71b9e6c72eaaaaa519dd59bd6897df4.tar.gz",
|
||||||
"hash": "08whn7l75qv5n74cifmnxc0s7n7ja1g7589pjnbbsk2djn6bqbky"
|
"hash": "08whn7l75qv5n74cifmnxc0s7n7ja1g7589pjnbbsk2djn6bqbky"
|
||||||
},
|
},
|
||||||
|
"typst-concealer": {
|
||||||
|
"type": "Git",
|
||||||
|
"repository": {
|
||||||
|
"type": "GitHub",
|
||||||
|
"owner": "PartyWumpus",
|
||||||
|
"repo": "typst-concealer"
|
||||||
|
},
|
||||||
|
"branch": "main",
|
||||||
|
"submodules": false,
|
||||||
|
"revision": "3d2e72ce7fc06bd0db0dafbdd1e17d3c9e343d53",
|
||||||
|
"url": "https://github.com/PartyWumpus/typst-concealer/archive/3d2e72ce7fc06bd0db0dafbdd1e17d3c9e343d53.tar.gz",
|
||||||
|
"hash": "16j3q3hk1wzgcz6snn9997vclhkanplyn0cp1dm9lk034jd8v9nh"
|
||||||
|
},
|
||||||
"typst-preview-nvim": {
|
"typst-preview-nvim": {
|
||||||
"type": "Git",
|
"type": "Git",
|
||||||
"repository": {
|
"repository": {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue