mirror of
https://github.com/nix-community/home-manager
synced 2025-01-11 03:29:50 +01:00
fnott: remove global properties generation
Rationale: As of release 1.1.2[1], the configuration ini file supports declaration of the `[main]` header as an alternative to global properties by enumerating all sections and mapping each to the respective parsing function. Global properties will still be parsed correctly by fnott however generation adds unnecessary complexity to the module. This commit removes the need for global properties generation. Changes: - Fixed the FIXME at L118. - Cleaned up unneeded let bindings. - Changed the generation method to use the `pkgs.formats.ini` from pkgs-lib instead of the raw `generators` library. This was done for consistency and clarity as the `pkgs.formats.ini` is still required for type declaration and uses `generators` internally. - Removed `global-properties` testcase. - Updated `example-settings` testcase. [1] - https://codeberg.org/dnkl/fnott/releases/tag/1.1.2
This commit is contained in:
parent
da8a78eec9
commit
46a69810cb
5 changed files with 7 additions and 48 deletions
|
@ -8,15 +8,7 @@ let
|
||||||
concatStringsSep' = sep: list:
|
concatStringsSep' = sep: list:
|
||||||
concatStringsSep sep (filter (x: x != "") list);
|
concatStringsSep sep (filter (x: x != "") list);
|
||||||
|
|
||||||
mkKeyValue = generators.mkKeyValueDefault { } "=";
|
iniFormat = pkgs.formats.ini { };
|
||||||
genINI = generators.toINI { };
|
|
||||||
|
|
||||||
iniFormatType = with types;
|
|
||||||
let
|
|
||||||
iniAtom = types.nullOr (types.oneOf [ bool int float str ]) // {
|
|
||||||
description = "INI atom (null, bool, int, float or string)";
|
|
||||||
};
|
|
||||||
in attrsOf (attrsOf iniAtom);
|
|
||||||
in {
|
in {
|
||||||
options = {
|
options = {
|
||||||
services.fnott = {
|
services.fnott = {
|
||||||
|
@ -58,7 +50,7 @@ in {
|
||||||
};
|
};
|
||||||
|
|
||||||
settings = mkOption {
|
settings = mkOption {
|
||||||
type = iniFormatType;
|
type = iniFormat.type;
|
||||||
default = { };
|
default = { };
|
||||||
description = ''
|
description = ''
|
||||||
Configuration written to
|
Configuration written to
|
||||||
|
@ -114,14 +106,7 @@ in {
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
xdg.configFile."fnott/fnott.ini" = {
|
xdg.configFile."fnott/fnott.ini".source =
|
||||||
# FIXME: Remove after next version release (https://codeberg.org/dnkl/fnott/pulls/24).
|
iniFormat.generate "fnott.ini" cfg.settings;
|
||||||
text = concatStringsSep' "\n" [
|
|
||||||
(optionalString (cfg.settings ? main) ''
|
|
||||||
${concatStringsSep "\n" (mapAttrsToList mkKeyValue cfg.settings.main)}
|
|
||||||
'')
|
|
||||||
(genINI (removeAttrs cfg.settings [ "main" ]))
|
|
||||||
];
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
{
|
{
|
||||||
fnott-example-settings = ./example-settings.nix;
|
fnott-example-settings = ./example-settings.nix;
|
||||||
fnott-global-properties = ./global-properties.nix;
|
|
||||||
fnott-systemd-user-service = ./systemd-user-service.nix;
|
fnott-systemd-user-service = ./systemd-user-service.nix;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
notification-margin=5
|
|
||||||
|
|
||||||
[low]
|
[low]
|
||||||
timeout=5
|
timeout=5
|
||||||
title-color=ffffff
|
title-color=ffffff
|
||||||
title-font=Dina:weight=bold:slant=italic
|
title-font=Dina:weight=bold:slant=italic
|
||||||
|
|
||||||
|
[main]
|
||||||
|
notification-margin=5
|
||||||
|
|
|
@ -1,2 +0,0 @@
|
||||||
max-icon-size=32
|
|
||||||
notification-margin=5
|
|
|
@ -1,24 +0,0 @@
|
||||||
{ config, lib, pkgs, ... }:
|
|
||||||
|
|
||||||
# FIXME: Deprecate on next version release of fnott (https://codeberg.org/dnkl/fnott/pulls/24).
|
|
||||||
{
|
|
||||||
config = {
|
|
||||||
services.fnott = {
|
|
||||||
enable = true;
|
|
||||||
package = config.lib.test.mkStubPackage { };
|
|
||||||
|
|
||||||
settings = {
|
|
||||||
main = {
|
|
||||||
max-icon-size = 32;
|
|
||||||
notification-margin = 5;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
nmt.script = ''
|
|
||||||
assertFileContent \
|
|
||||||
home-files/.config/fnott/fnott.ini \
|
|
||||||
${./global-properties-expected.ini}
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
}
|
|
Loading…
Reference in a new issue