push sheeet
Some checks failed
Periodic Merges (6h) / master → staging-nixos (push) Failing after 12m50s
Periodic Merges (6h) / master → staging-next (push) Failing after 12m54s
Periodic Merges (24h) / merge-base(master,staging) → haskell-updates (push) Failing after 11m54s
Periodic Merges (6h) / staging-next → staging (push) Failing after 12m13s
Periodic Merges (24h) / staging-next-25.05 → staging-25.05 (push) Failing after 13m24s
Periodic Merges (24h) / release-25.05 → staging-next-25.05 (push) Failing after 14m28s

This commit is contained in:
Dark Steveneq
2025-10-09 14:15:47 +02:00
commit 646b892680
49168 changed files with 5897842 additions and 0 deletions

View File

@@ -0,0 +1,27 @@
{ lib, config, ... }:
let
inherit (lib) types;
in
{
options = {
fun = lib.mkOption {
type = types.functionTo (types.listOf types.str);
};
result = lib.mkOption {
type = types.str;
default = toString (
config.fun {
a = "a";
b = "b";
c = "c";
}
);
};
};
config.fun = lib.mkMerge [
(input: lib.mkAfter [ input.a ])
(input: [ input.b ])
];
}

View File

@@ -0,0 +1,32 @@
{ lib, config, ... }:
let
inherit (lib) types;
in
{
options = {
fun = lib.mkOption {
type = types.functionTo (types.attrsOf types.str);
};
result = lib.mkOption {
type = types.str;
default = toString (
lib.attrValues (
config.fun {
a = "a";
b = "b";
c = "c";
}
)
);
};
};
config.fun = lib.mkMerge [
(input: { inherit (input) a; })
(input: { inherit (input) b; })
(input: {
b = lib.mkForce input.c;
})
];
}

View File

@@ -0,0 +1,27 @@
{ lib, config, ... }:
let
inherit (lib) types;
in
{
options = {
fun = lib.mkOption {
type = types.functionTo (types.listOf types.str);
};
result = lib.mkOption {
type = types.str;
default = toString (
config.fun {
a = "a";
b = "b";
c = "c";
}
);
};
};
config.fun = lib.mkMerge [
(input: [ input.a ])
(input: [ input.b ])
];
}

View File

@@ -0,0 +1,69 @@
{
lib,
config,
options,
...
}:
let
inherit (lib) types;
in
{
imports = [
# fun.<function-body>.a
(
{ ... }:
{
options = {
fun = lib.mkOption {
type = types.functionTo (
types.submodule {
options.a = lib.mkOption { default = "a"; };
}
);
};
};
}
)
# fun.<function-body>.b
(
{ ... }:
{
options = {
fun = lib.mkOption {
type = types.functionTo (
types.submodule {
options.b = lib.mkOption { default = "b"; };
}
);
};
};
}
)
];
options = {
result = lib.mkOption {
type = types.str;
default = lib.concatStringsSep " " (
lib.attrValues (config.fun (throw "shouldn't use input param"))
);
};
optionsResult = lib.mkOption {
type = types.str;
default = lib.concatStringsSep " " (
lib.concatLists (
lib.mapAttrsToList (k: v: if k == "_module" then [ ] else [ (lib.showOption v.loc) ]) (
options.fun.type.getSubOptions [ "fun" ]
)
)
);
};
};
config.fun = lib.mkMerge [
(input: { b = "bee"; })
];
}

View File

@@ -0,0 +1,18 @@
{ lib, config, ... }:
let
inherit (lib) types;
in
{
options = {
fun = lib.mkOption {
type = types.functionTo types.str;
};
result = lib.mkOption {
type = types.str;
default = config.fun "input";
};
};
config.fun = input: "input is ${input}";
}

View File

@@ -0,0 +1,18 @@
{ lib, config, ... }:
let
inherit (lib) types;
in
{
options = {
fun = lib.mkOption {
type = types.functionTo types.str;
};
result = lib.mkOption {
type = types.str;
default = config.fun 0;
};
};
config.fun = input: input + 1;
}