Compare commits

..

No commits in common. "866b983c4047b87bcdca6ab3673ed7bd602f0251" and "39813f03226d0c603a85458d2bdf27e947b593da" have entirely different histories.

6 changed files with 13 additions and 91 deletions

View file

@ -93,7 +93,7 @@ isMaximal: {
fsharp.enable = false; fsharp.enable = false;
just.enable = false; just.enable = false;
qml.enable = false; qml.enable = false;
jinja.enable = false;
tailwind.enable = false; tailwind.enable = false;
svelte.enable = false; svelte.enable = false;

View file

@ -132,9 +132,6 @@
- Added [sqruff](https://github.com/quarylabs/sqruff) support to `languages.sql` - Added [sqruff](https://github.com/quarylabs/sqruff) support to `languages.sql`
- Lazy-load `crates.nvim` plugin when using
`vim.languages.rust.extensions.crates-nvim.enable`
- Added [Pyrefly](https://pyrefly.org/) and [zuban](https://zubanls.com/) - Added [Pyrefly](https://pyrefly.org/) and [zuban](https://zubanls.com/)
support to `languages.python` support to `languages.python`
@ -142,14 +139,9 @@
[Tombi](https://tombi-toml.github.io/tombi/) language server, linter, and [Tombi](https://tombi-toml.github.io/tombi/) language server, linter, and
formatter. formatter.
- Added Jinja support via `languages.jinja`
- Added [hlargs.nvim](https://github.com/m-demare/hlargs.nvim) support as - Added [hlargs.nvim](https://github.com/m-demare/hlargs.nvim) support as
`visuals.hlargs-nvim`. `visuals.hlargs-nvim`.
- Lazy-load `nvim-autopairs` plugin when using
`vim.autopairs.nvim-autopairs.enable`
[Machshev](https://github.com/machshev): [Machshev](https://github.com/machshev):
- Added `ruff` and `ty` LSP support for Python under `programs.python`. - Added `ruff` and `ty` LSP support for Python under `programs.python`.

View file

@ -4,14 +4,17 @@
... ...
}: let }: let
inherit (lib.modules) mkIf; inherit (lib.modules) mkIf;
inherit (lib.nvim.dag) entryAnywhere;
inherit (lib.nvim.lua) toLuaObject;
cfg = config.vim.autopairs.nvim-autopairs; cfg = config.vim.autopairs.nvim-autopairs;
in { in {
config = mkIf cfg.enable { config = mkIf cfg.enable {
vim.lazy.plugins.nvim-autopairs = { vim = {
package = "nvim-autopairs"; startPlugins = ["nvim-autopairs"];
setupModule = "nvim-autopairs"; pluginRC.autopairs = entryAnywhere ''
setupOpts = cfg.setupOpts; require('nvim-autopairs').setup(${toLuaObject cfg.setupOpts})
event = ["InsertEnter"]; '';
}; };
}; };
} }

View file

@ -21,7 +21,6 @@ in {
./html.nix ./html.nix
./haskell.nix ./haskell.nix
./java.nix ./java.nix
./jinja.nix
./json.nix ./json.nix
./lua.nix ./lua.nix
./markdown.nix ./markdown.nix

View file

@ -1,65 +0,0 @@
{
config,
pkgs,
lib,
...
}: let
inherit (builtins) attrNames;
inherit (lib.meta) getExe;
inherit (lib.modules) mkIf mkMerge;
inherit (lib.options) mkEnableOption mkOption;
inherit (lib.types) enum listOf;
inherit (lib.nvim.types) mkGrammarOption;
inherit (lib.nvim.attrsets) mapListToAttrs;
cfg = config.vim.languages.jinja;
defaultServers = ["jinja-lsp"];
servers = {
jinja-lsp = {
enable = true;
cmd = [(getExe pkgs.jinja-lsp)];
filetypes = ["jinja"];
root_markers = [
".git"
];
};
};
in {
options.vim.languages.jinja = {
enable = mkEnableOption "Jinja template language support";
treesitter = {
enable = mkEnableOption "Jinja treesitter" // {default = config.vim.languages.enableTreesitter;};
package = mkGrammarOption pkgs "jinja";
inlinePackage = mkGrammarOption pkgs "jinja_inline";
};
lsp = {
enable = mkEnableOption "Jinja LSP support" // {default = config.vim.lsp.enable;};
servers = mkOption {
description = "Jinja LSP server to use";
type = listOf (enum (attrNames servers));
default = defaultServers;
};
};
};
config = mkIf cfg.enable (mkMerge [
(mkIf cfg.treesitter.enable {
vim.treesitter.enable = true;
vim.treesitter.grammars = [
cfg.treesitter.package
cfg.treesitter.inlinePackage
];
})
(mkIf cfg.lsp.enable {
vim.lsp.servers =
mapListToAttrs (n: {
name = n;
value = servers.${n};
})
cfg.lsp.servers;
})
]);
}

View file

@ -228,17 +228,10 @@ in {
(mkIf cfg.extensions.crates-nvim.enable { (mkIf cfg.extensions.crates-nvim.enable {
vim = mkMerge [ vim = mkMerge [
{ {
lazy.plugins.crates-nvim = { startPlugins = ["crates-nvim"];
package = "crates-nvim"; pluginRC.rust-crates = entryAnywhere ''
setupModule = "crates"; require("crates").setup(${toLuaObject cfg.extensions.crates-nvim.setupOpts})
setupOpts = cfg.extensions.crates-nvim.setupOpts; '';
event = [
{
event = "BufRead";
pattern = "Cargo.toml";
}
];
};
} }
]; ];
}) })