mirror of
https://github.com/nix-community/home-manager
synced 2025-01-12 20:19:50 +01:00
bat: allow setting themes/syntaxes without IFD
The way the `bat` module is currently written makes it essentially impossible to use themes and syntaxes without IFD, since you must provide the contents as string, instead of just giving a path to be linked. With this change, setting themes/syntaxes by-string will start issuing warnings, and a new attribute model is added, lightly inspired by how `programs.zsh.plugins` avoided this issue.
This commit is contained in:
parent
149a52a414
commit
8a719ddd3c
4 changed files with 164 additions and 36 deletions
|
@ -43,16 +43,33 @@ in {
|
||||||
};
|
};
|
||||||
|
|
||||||
themes = mkOption {
|
themes = mkOption {
|
||||||
type = types.attrsOf types.lines;
|
type = types.attrsOf (types.either types.lines (types.submodule {
|
||||||
|
options = {
|
||||||
|
src = mkOption {
|
||||||
|
type = types.path;
|
||||||
|
description = "Path to the theme folder.";
|
||||||
|
};
|
||||||
|
|
||||||
|
file = mkOption {
|
||||||
|
type = types.nullOr types.str;
|
||||||
|
default = null;
|
||||||
|
description =
|
||||||
|
"Subpath of the theme file within the source, if needed.";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}));
|
||||||
default = { };
|
default = { };
|
||||||
example = literalExpression ''
|
example = literalExpression ''
|
||||||
{
|
{
|
||||||
dracula = builtins.readFile (pkgs.fetchFromGitHub {
|
dracula = {
|
||||||
owner = "dracula";
|
src = pkgs.fetchFromGitHub {
|
||||||
repo = "sublime"; # Bat uses sublime syntax for its themes
|
owner = "dracula";
|
||||||
rev = "26c57ec282abcaa76e57e055f38432bd827ac34e";
|
repo = "sublime"; # Bat uses sublime syntax for its themes
|
||||||
sha256 = "019hfl4zbn4vm4154hh3bwk6hm7bdxbr1hdww83nabxwjn99ndhv";
|
rev = "26c57ec282abcaa76e57e055f38432bd827ac34e";
|
||||||
} + "/Dracula.tmTheme");
|
sha256 = "019hfl4zbn4vm4154hh3bwk6hm7bdxbr1hdww83nabxwjn99ndhv";
|
||||||
|
};
|
||||||
|
file = "Dracula.tmTheme";
|
||||||
|
};
|
||||||
}
|
}
|
||||||
'';
|
'';
|
||||||
description = ''
|
description = ''
|
||||||
|
@ -61,43 +78,84 @@ in {
|
||||||
};
|
};
|
||||||
|
|
||||||
syntaxes = mkOption {
|
syntaxes = mkOption {
|
||||||
type = types.attrsOf types.lines;
|
type = types.attrsOf (types.either types.lines (types.submodule {
|
||||||
|
options = {
|
||||||
|
src = mkOption {
|
||||||
|
type = types.path;
|
||||||
|
description = "Path to the syntax folder.";
|
||||||
|
};
|
||||||
|
file = mkOption {
|
||||||
|
type = types.nullOr types.str;
|
||||||
|
default = null;
|
||||||
|
description =
|
||||||
|
"Subpath of the syntax file within the source, if needed.";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}));
|
||||||
default = { };
|
default = { };
|
||||||
example = literalExpression ''
|
example = literalExpression ''
|
||||||
{
|
{
|
||||||
syntaxes.gleam = builtins.readFile (pkgs.fetchFromGitHub {
|
gleam = {
|
||||||
owner = "molnarmark";
|
src = pkgs.fetchFromGitHub {
|
||||||
repo = "sublime-gleam";
|
owner = "molnarmark";
|
||||||
rev = "2e761cdb1a87539d827987f997a20a35efd68aa9";
|
repo = "sublime-gleam";
|
||||||
hash = "sha256-Zj2DKTcO1t9g18qsNKtpHKElbRSc9nBRE2QBzRn9+qs=";
|
rev = "2e761cdb1a87539d827987f997a20a35efd68aa9";
|
||||||
} + "/syntax/gleam.sublime-syntax");
|
hash = "sha256-Zj2DKTcO1t9g18qsNKtpHKElbRSc9nBRE2QBzRn9+qs=";
|
||||||
|
};
|
||||||
|
file = "syntax/gleam.sublime-syntax";
|
||||||
|
};
|
||||||
}
|
}
|
||||||
'';
|
'';
|
||||||
description = ''
|
description = ''
|
||||||
Additional syntaxes to provide.
|
Additional syntaxes to provide.
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable (mkMerge [
|
||||||
home.packages = [ package ] ++ cfg.extraPackages;
|
(mkIf (any isString (attrValues cfg.themes)) {
|
||||||
|
warnings = [''
|
||||||
|
Using programs.bat.themes as a string option is deprecated and will be
|
||||||
|
removed in the future. Please change to using it as an attribute set
|
||||||
|
instead.
|
||||||
|
''];
|
||||||
|
})
|
||||||
|
(mkIf (any isString (attrValues cfg.syntaxes)) {
|
||||||
|
warnings = [''
|
||||||
|
Using programs.bat.syntaxes as a string option is deprecated and will be
|
||||||
|
removed in the future. Please change to using it as an attribute set
|
||||||
|
instead.
|
||||||
|
''];
|
||||||
|
})
|
||||||
|
{
|
||||||
|
home.packages = [ package ] ++ cfg.extraPackages;
|
||||||
|
|
||||||
xdg.configFile = mkMerge ([{
|
xdg.configFile = mkMerge ([({
|
||||||
"bat/config" =
|
"bat/config" =
|
||||||
mkIf (cfg.config != { }) { text = toConfigFile cfg.config; };
|
mkIf (cfg.config != { }) { text = toConfigFile cfg.config; };
|
||||||
}] ++ flip mapAttrsToList cfg.themes
|
})] ++ (flip mapAttrsToList cfg.themes (name: val: {
|
||||||
(name: body: { "bat/themes/${name}.tmTheme" = { text = body; }; })
|
"bat/themes/${name}.tmTheme" = if isString val then {
|
||||||
++ flip mapAttrsToList cfg.syntaxes (name: body: {
|
text = val;
|
||||||
"bat/syntaxes/${name}.sublime-syntax" = { text = body; };
|
} else {
|
||||||
}));
|
source =
|
||||||
|
if isNull val.file then "${val.src}" else "${val.src}/${val.file}";
|
||||||
|
};
|
||||||
|
})) ++ (flip mapAttrsToList cfg.syntaxes (name: val: {
|
||||||
|
"bat/syntaxes/${name}.sublime-syntax" = if isString val then {
|
||||||
|
text = val;
|
||||||
|
} else {
|
||||||
|
source =
|
||||||
|
if isNull val.file then "${val.src}" else "${val.src}/${val.file}";
|
||||||
|
};
|
||||||
|
})));
|
||||||
|
|
||||||
home.activation.batCache = hm.dag.entryAfter [ "linkGeneration" ] ''
|
home.activation.batCache = hm.dag.entryAfter [ "linkGeneration" ] ''
|
||||||
(
|
(
|
||||||
export XDG_CACHE_HOME=${escapeShellArg config.xdg.cacheHome}
|
export XDG_CACHE_HOME=${escapeShellArg config.xdg.cacheHome}
|
||||||
$VERBOSE_ECHO "Rebuilding bat theme cache"
|
$VERBOSE_ECHO "Rebuilding bat theme cache"
|
||||||
$DRY_RUN_CMD ${lib.getExe package} cache --build
|
$DRY_RUN_CMD ${lib.getExe package} cache --build
|
||||||
)
|
)
|
||||||
'';
|
'';
|
||||||
};
|
}
|
||||||
|
]);
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,11 +13,11 @@ with lib;
|
||||||
map-syntax = [ "*.jenkinsfile:Groovy" "*.props:Java Properties" ];
|
map-syntax = [ "*.jenkinsfile:Groovy" "*.props:Java Properties" ];
|
||||||
};
|
};
|
||||||
|
|
||||||
themes.testtheme = ''
|
themes.testtheme.src = pkgs.writeText "testtheme.tmTheme" ''
|
||||||
This is a test theme.
|
This is a test theme.
|
||||||
'';
|
'';
|
||||||
|
|
||||||
syntaxes.testsyntax = ''
|
syntaxes.testsyntax.src = pkgs.writeText "testsyntax.sublime-syntax" ''
|
||||||
This is a test syntax.
|
This is a test syntax.
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
|
@ -1 +1,4 @@
|
||||||
{ bat = ./bat.nix; }
|
{
|
||||||
|
bat = ./bat.nix;
|
||||||
|
bat-deprecated-options = ./deprecated-options.nix;
|
||||||
|
}
|
||||||
|
|
67
tests/modules/programs/bat/deprecated-options.nix
Normal file
67
tests/modules/programs/bat/deprecated-options.nix
Normal file
|
@ -0,0 +1,67 @@
|
||||||
|
{ config, lib, pkgs, ... }:
|
||||||
|
|
||||||
|
with lib;
|
||||||
|
|
||||||
|
{
|
||||||
|
config = {
|
||||||
|
programs.bat = {
|
||||||
|
enable = true;
|
||||||
|
|
||||||
|
config = {
|
||||||
|
theme = "TwoDark";
|
||||||
|
pager = "less -FR";
|
||||||
|
map-syntax = [ "*.jenkinsfile:Groovy" "*.props:Java Properties" ];
|
||||||
|
};
|
||||||
|
|
||||||
|
themes.testtheme = ''
|
||||||
|
This is a test theme.
|
||||||
|
'';
|
||||||
|
|
||||||
|
syntaxes.testsyntax = ''
|
||||||
|
This is a test syntax.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
test.stubs.bat = { };
|
||||||
|
|
||||||
|
test.asserts.warnings.enable = true;
|
||||||
|
test.asserts.warnings.expected = [
|
||||||
|
''
|
||||||
|
Using programs.bat.themes as a string option is deprecated and will be
|
||||||
|
removed in the future. Please change to using it as an attribute set
|
||||||
|
instead.
|
||||||
|
''
|
||||||
|
''
|
||||||
|
Using programs.bat.syntaxes as a string option is deprecated and will be
|
||||||
|
removed in the future. Please change to using it as an attribute set
|
||||||
|
instead.
|
||||||
|
''
|
||||||
|
];
|
||||||
|
|
||||||
|
nmt.script = ''
|
||||||
|
assertFileExists home-files/.config/bat/config
|
||||||
|
assertFileContent home-files/.config/bat/config ${
|
||||||
|
pkgs.writeText "bat.expected" ''
|
||||||
|
--map-syntax='*.jenkinsfile:Groovy'
|
||||||
|
--map-syntax='*.props:Java Properties'
|
||||||
|
--pager='less -FR'
|
||||||
|
--theme='TwoDark'
|
||||||
|
''
|
||||||
|
}
|
||||||
|
|
||||||
|
assertFileExists home-files/.config/bat/themes/testtheme.tmTheme
|
||||||
|
assertFileContent home-files/.config/bat/themes/testtheme.tmTheme ${
|
||||||
|
pkgs.writeText "bat.expected" ''
|
||||||
|
This is a test theme.
|
||||||
|
''
|
||||||
|
}
|
||||||
|
|
||||||
|
assertFileExists home-files/.config/bat/syntaxes/testsyntax.sublime-syntax
|
||||||
|
assertFileContent home-files/.config/bat/syntaxes/testsyntax.sublime-syntax ${
|
||||||
|
pkgs.writeText "bat.expected" ''
|
||||||
|
This is a test syntax.
|
||||||
|
''
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
}
|
Loading…
Reference in a new issue