Merge pull request #1524 from snoweuph/feat/emmet-them-all
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 documentation builds-1 (push) Waiting to run
Treewide Checks / Validate documentation builds-2 (push) Waiting to run
Treewide Checks / Validate documentation builds-3 (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

Emmet them all
This commit is contained in:
Snoweuph 2026-04-16 23:49:41 +02:00 committed by GitHub
commit 029ca6d34a
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
6 changed files with 69 additions and 5 deletions

View file

@ -316,6 +316,13 @@
- Added Makefile support via `languages.make`. - Added Makefile support via `languages.make`.
- Add `lsp.presets.emmet-ls` as supported LSP to
- `languages.jinja`
- `languages.liquid`
- `languages.tera`
- `languages.twig`
- `languages.astro`
- Fix `languages.hcl` init, depending on `comment-nvim` by checking if it is - Fix `languages.hcl` init, depending on `comment-nvim` by checking if it is
enabled. Fixes a crash (#1350). enabled. Fixes a crash (#1350).

View file

@ -17,7 +17,7 @@
cfg = config.vim.languages.astro; cfg = config.vim.languages.astro;
defaultServers = ["astro-language-server"]; defaultServers = ["astro-language-server"];
servers = ["astro-language-server"]; servers = ["astro-language-server" "emmet-ls"];
defaultFormat = ["prettier"]; defaultFormat = ["prettier"];
formats = let formats = let

View file

@ -13,7 +13,7 @@
cfg = config.vim.languages.jinja; cfg = config.vim.languages.jinja;
defaultServers = ["jinja-lsp"]; defaultServers = ["jinja-lsp"];
servers = ["jinja-lsp"]; servers = ["jinja-lsp" "emmet-ls"];
in { in {
options.vim.languages.jinja = { options.vim.languages.jinja = {
enable = mkEnableOption "Jinja template language support"; enable = mkEnableOption "Jinja template language support";

View file

@ -4,11 +4,16 @@
lib, lib,
... ...
}: let }: let
inherit (lib.options) mkEnableOption literalExpression; inherit (lib) genAttrs;
inherit (lib.options) mkEnableOption literalExpression mkOption;
inherit (lib.modules) mkIf mkMerge; inherit (lib.modules) mkIf mkMerge;
inherit (lib.types) enum listOf;
inherit (lib.nvim.types) mkGrammarOption; inherit (lib.nvim.types) mkGrammarOption;
cfg = config.vim.languages.liquid; cfg = config.vim.languages.liquid;
defaultServers = [];
servers = ["emmet-ls"];
in { in {
options.vim.languages.liquid = { options.vim.languages.liquid = {
enable = mkEnableOption "Liquid templating language support"; enable = mkEnableOption "Liquid templating language support";
@ -22,6 +27,21 @@ in {
}; };
package = mkGrammarOption pkgs "liquid"; package = mkGrammarOption pkgs "liquid";
}; };
lsp = {
enable =
mkEnableOption "Liquid LSP support"
// {
default = config.vim.lsp.enable;
defaultText = literalExpression "config.vim.lsp.enable";
};
servers = mkOption {
description = "Liquid LSP server to use";
type = listOf (enum servers);
default = defaultServers;
};
};
# TODO: if curlylint gets packaged for nix, add it. # TODO: if curlylint gets packaged for nix, add it.
}; };
@ -30,5 +50,14 @@ in {
vim.treesitter.enable = true; vim.treesitter.enable = true;
vim.treesitter.grammars = [cfg.treesitter.package]; vim.treesitter.grammars = [cfg.treesitter.package];
}) })
(mkIf cfg.lsp.enable {
vim.lsp = {
presets = genAttrs cfg.lsp.servers (_: {enable = true;});
servers = genAttrs cfg.lsp.servers (_: {
filetypes = ["liquid"];
});
};
})
]); ]);
} }

View file

@ -4,11 +4,16 @@
lib, lib,
... ...
}: let }: let
inherit (lib.options) mkEnableOption literalExpression; inherit (lib) genAttrs;
inherit (lib.options) mkEnableOption literalExpression mkOption;
inherit (lib.modules) mkIf mkMerge; inherit (lib.modules) mkIf mkMerge;
inherit (lib.types) enum listOf;
inherit (lib.nvim.types) mkGrammarOption; inherit (lib.nvim.types) mkGrammarOption;
cfg = config.vim.languages.tera; cfg = config.vim.languages.tera;
defaultServers = [];
servers = ["emmet-ls"];
in { in {
options.vim.languages.tera = { options.vim.languages.tera = {
enable = mkEnableOption "Tera templating language support"; enable = mkEnableOption "Tera templating language support";
@ -22,6 +27,20 @@ in {
}; };
package = mkGrammarOption pkgs "tera"; package = mkGrammarOption pkgs "tera";
}; };
lsp = {
enable =
mkEnableOption "Tera LSP support"
// {
default = config.vim.lsp.enable;
defaultText = literalExpression "config.vim.lsp.enable";
};
servers = mkOption {
description = "Tera LSP server to use";
type = listOf (enum servers);
default = defaultServers;
};
};
}; };
config = mkIf cfg.enable (mkMerge [ config = mkIf cfg.enable (mkMerge [
@ -29,5 +48,14 @@ in {
vim.treesitter.enable = true; vim.treesitter.enable = true;
vim.treesitter.grammars = [cfg.treesitter.package]; vim.treesitter.grammars = [cfg.treesitter.package];
}) })
(mkIf cfg.lsp.enable {
vim.lsp = {
presets = genAttrs cfg.lsp.servers (_: {enable = true;});
servers = genAttrs cfg.lsp.servers (_: {
filetypes = ["tera"];
});
};
})
]); ]);
} }

View file

@ -16,7 +16,7 @@
cfg = config.vim.languages.twig; cfg = config.vim.languages.twig;
defaultServers = ["twig-language-server"]; defaultServers = ["twig-language-server"];
servers = ["twig-language-server"]; servers = ["twig-language-server" "emmet-ls"];
defaultFormat = ["djlint"]; defaultFormat = ["djlint"];
formats = { formats = {