1

Nixos: Remove mkLink + mkEnableOpt and rename mkBoolOpt

This commit is contained in:
2024-10-12 17:31:01 +02:00
parent bd50e4539e
commit 4eddef07be
32 changed files with 156 additions and 172 deletions

View File

@ -1,63 +1,44 @@
# TODO: Easier mkLink/mkUnlink (include more hm.dag stuff into the function)
{
inputs,
pkgs,
lib,
...
}: rec {
# Conveniance wrapper for mkOption with boolean type
mkBoolOpt = def: desc:
# Convenience wrapper for "mkOption" with boolean type.
mkBoolOption = def: desc:
lib.mkOption {
type = lib.types.bool;
default = def;
description = desc;
};
# Alias for consistency
mkEnableOpt = lib.mkEnableOption;
# Like mkIf but the predicate is inverted
# Like "lib.mkIf" but the predicate is inverted.
# Returns "do" if "pred" is false.
mkElse = pred: do: (lib.mkIf (!pred) do);
# Creates a symlink if it doesn't exist
# If it exists renew the link
mkLink = src: dest: ''
if [ -L "${dest}" ]; then
rm ${dest}
fi
ln -sf ${src} ${dest}
'';
# Removes a symlink if it exists
mkUnlink = dest: ''
if [ -L "${dest}" ]; then
rm ${dest}
fi
'';
# Returns true if base contains element
# Returns "true" if "base" contains "element".
contains = base: element:
lib.any (x: x == element) base;
# Returns base without occurences of elements that are also in remove
# Returns "base" without occurences of elements that are also in "remove".
without = base: remove:
lib.filter (x: !(contains remove x)) base;
# For use with single element sets
# Used with attrSets with a single element.
# Returns the name of the single attr.
attrName = set: let
names = lib.attrNames set;
in (
in
if (names != [])
then (lib.head names)
else null
);
else null;
# For use with single element sets
# Used with attrSets with a single element.
# Returns the value of the single attr.
attrValue = set: let
values = lib.attrValues set;
in (
in
if (values != [])
then (lib.head values)
else null
);
else null;
}