more rework

main
Zynh Ludwig 2024-06-28 07:48:26 -07:00
parent 4213303810
commit 608982d8f2
2 changed files with 46 additions and 19 deletions

View File

@ -17,17 +17,16 @@
};
};
outputs = { self, nixpkgs, ... }@inputs:
outputs =
{ self, nixpkgs, ... }@inputs:
{
nixosConfigurations =
let
lib = import ./lib { inherit (nixpkgs) lib; };
cleanHostname = config: builtins.removeAttrs config [ "hostname" ];
toNixosConfigPart = config: { name = config.hostname; value = nixpkgs.lib.nixosSystem (cleanHostname config); };
in
builtins.listToAttrs
(map toNixosConfigPart
(map
({ hostname, system }: {
toPartialNixosConfigSet = config: { name = config.hostname; value = nixpkgs.lib.nixosSystem (cleanHostname config); };
toNixosSystemConfig = { hostname, system }: {
inherit system hostname;
specialArgs = { inherit inputs; };
modules = [
@ -35,11 +34,23 @@
./hosts/${hostname}/configuration.nix
inputs.home-manager.nixosModules.default
];
})
};
compileSystems = systems: lib.right builtins.listToAttrs (map toPartialNixosConfigSet) (map toNixosSystemConfig) systems;
in
compileSystems
[
{ hostname = "snowhawk"; system = "x86_64-linux"; }
{ hostname = "sprite"; system = "aarch64-linux"; }
{ hostname = "nixos"; system = "x86_64-linux"; }
]));
{
hostname = "snowhawk";
system = "x86_64-linux";
}
{
hostname = "sprite";
system = "aarch64-linux";
}
{
hostname = "nixos";
system = "x86_64-linux";
}
];
};
}

16
lib/default.nix Normal file
View File

@ -0,0 +1,16 @@
{ lib, ... }:
with lib;
rec {
# Ternary operator
# Exaample:
# tern false 1 2 => 2
# tern true 1 2 => 1
tern = pred: x: y: if pred then x else y;
# Right-associate and chain following single-operand functions
# Example:
# right f g h 1 => f(g(h(1)))
right = f: g: tern (isFunction g)
(right (x: f (g (x))))
(f (g));
}