move tree config to another file to tidy up outputs.nix

This commit is contained in:
ChaotiCryptidz 2022-03-02 17:49:49 +00:00
parent 7b0310b368
commit e4e76442d9
No known key found for this signature in database
5 changed files with 67 additions and 71 deletions

View file

@ -5,29 +5,11 @@ let
tree.impure.modules.nixos tree.impure.modules.nixos
tree.impure.profiles.base tree.impure.profiles.base
]; ];
defaultModulesNixOSUnstable = defaultModules ++ [
# NO_INLINE
inputs.home-manager-unstable.nixosModules.home-manager
];
defaultSpecialArgs = { defaultSpecialArgs = {
tree = tree.impure; tree = tree.impure;
pureTree = tree.pure; pureTree = tree.pure;
}; };
defaultSpecialArgsNixOSUnstable = defaultSpecialArgs // {
inputs = inputs // {
# set these to the correct versions from inputs
nixpkgs = inputs.nixpkgs-unstable;
home-manager = inputs.home-manager-unstable;
};
};
nixosUnstableSystem = nixpkgs-unstable.lib.nixosSystem;
in { in {
inherit defaultModules; inherit defaultModules;
inherit defaultModulesNixOSUnstable; inherit defaultSpecialArgs;
inherit defaultSpecialArgs;
inherit defaultSpecialArgsNixOSUnstable;
} }

View file

@ -3,41 +3,52 @@ let
defaults = import ./defaults.nix inputs; defaults = import ./defaults.nix inputs;
defaultModulesNixOSUnstable = defaults.defaultModulesNixOSUnstable;
defaultSpecialArgsNixOSUnstable = defaults.defaultSpecialArgsNixOSUnstable;
nixosUnstableSystem = nixpkgs-unstable.lib.nixosSystem;
defaultSpecialArgs = defaults.defaultSpecialArgs // {
inputs = inputs // {
# set these to the correct versions from inputs
nixpkgs = inputs.nixpkgs-unstable;
home-manager = inputs.home-manager-unstable;
};
};
defaultModules = defaults.defaultModules ++ [
# NO_INLINE
inputs.home-manager-unstable.nixosModules.home-manager
];
nixosUnstableSystem = nixpkgs-unstable.lib.nixosSystem;
in { in {
lappy = nixosUnstableSystem { lappy = nixosUnstableSystem {
specialArgs = defaultSpecialArgsNixOSUnstable; specialArgs = defaultSpecialArgs;
system = "x86_64-linux"; system = "x86_64-linux";
modules = defaultModulesNixOSUnstable modules = defaultModules
++ [ ./lappy/lappy.nix ./lappy/hardware.nix ]; ++ [ ./lappy/lappy.nix ./lappy/hardware.nix ];
}; };
lappy-vm = nixosUnstableSystem { lappy-vm = nixosUnstableSystem {
specialArgs = defaultSpecialArgsNixOSUnstable; specialArgs = defaultSpecialArgs;
system = "x86_64-linux"; system = "x86_64-linux";
modules = defaultModulesNixOSUnstable modules = defaultModules
++ [ ./lappy/lappy.nix ./lappy/vm.nix ]; ++ [ ./lappy/lappy.nix ./lappy/vm.nix ];
}; };
rescue-x86_64 = nixosUnstableSystem { rescue-x86_64 = nixosUnstableSystem {
specialArgs = defaultSpecialArgsNixOSUnstable; specialArgs = defaultSpecialArgs;
system = "x86_64-linux"; system = "x86_64-linux";
modules = defaultModulesNixOSUnstable ++ [ ./rescue/rescue.nix ]; modules = defaultModules ++ [ ./rescue/rescue.nix ];
}; };
hetzner-vm = nixosUnstableSystem { hetzner-vm = nixosUnstableSystem {
specialArgs = defaultSpecialArgsNixOSUnstable; specialArgs = defaultSpecialArgs;
system = "x86_64-linux"; system = "x86_64-linux";
modules = defaultModulesNixOSUnstable ++ [ ./hetzner-vm/hetzner-vm.nix ]; modules = defaultModules ++ [ ./hetzner-vm/hetzner-vm.nix ];
}; };
# nix --no-sandbox build .#nixosConfigurations.raspberry.config.system.build.sdImage # nix --no-sandbox build .#nixosConfigurations.raspberry.config.system.build.sdImage
raspberry = nixosUnstableSystem { raspberry = nixosUnstableSystem {
specialArgs = defaultSpecialArgsNixOSUnstable; specialArgs = defaultSpecialArgs;
system = "aarch64-linux"; system = "aarch64-linux";
modules = defaultModulesNixOSUnstable ++ [ ./raspberry/raspberry.nix ]; modules = defaultModules ++ [ ./raspberry/raspberry.nix ];
}; };
} }

View file

@ -1,44 +1,9 @@
{ self, nixpkgs-unstable, deploy-rs, ... }@inputs: { self, nixpkgs-unstable, deploy-rs, ... }@inputs:
let let
mkTree = import ./tree.nix { inherit (nixpkgs-unstable) lib; }; mkTree = import ./tree.nix { inherit (nixpkgs-unstable) lib; };
pkgs-x86_64-linux = nixpkgs-unstable.legacyPackages.x86_64-linux; tree = (import ./treeConfig.nix { inherit mkTree; }).tree;
tree = mkTree {
inherit inputs;
folder = ./.;
config = {
"hosts/*/services".functor.enable = true;
"hosts/raspberry/services/music-friend".functor.enable = true;
"hosts/*/home".functor.enable = true;
"hosts/*/profiles".functor.enable = true;
"profiles/*".functor.enable = true;
"profiles/sound/*".functor.enable = true;
"profiles/sound/pulseaudio/*".functor.enable = true;
"profiles/connectivity/*".functor.enable = true;
"profiles/gaming/*".functor.enable = true;
"profiles/gui/environments/*".functor.enable = true;
"users/*".functor.enable = true;
"home/*".functor.enable = true;
"home/gui/environments/*".functor.enable = true;
"home/apps/*".functor.enable = true;
"home/gaming/emulators/*".functor.enable = true;
"home/gaming/games/*".functor.enable = true;
"home/gaming/platforms/*".functor.enable = true;
"home/programming/languages/*".functor.enable = true; pkgs-x86_64-linux = nixpkgs-unstable.legacyPackages.x86_64-linux;
"modules/nixos" = {
functor = {
enable = true;
external = [ ];
};
};
"modules/home" = {
functor = {
enable = true;
external = [ ];
};
};
};
};
hosts = import ./hosts ({ inherit tree; } // inputs); hosts = import ./hosts ({ inherit tree; } // inputs);
in { in {
nixosConfigurations = hosts.nixosConfigurations; nixosConfigurations = hosts.nixosConfigurations;

View file

@ -1,5 +1,5 @@
{ lib }: { lib }:
{ config, folder, inputs, ... }@args: { config, folder, ... }@args:
with lib; with lib;
let let
# Made by kat witch (kittywitch) # Made by kat witch (kittywitch)

38
treeConfig.nix Normal file
View file

@ -0,0 +1,38 @@
{mkTree, ...}: {
tree = mkTree {
folder = ./.;
config = {
"hosts/*/services".functor.enable = true;
"hosts/raspberry/services/music-friend".functor.enable = true;
"hosts/*/home".functor.enable = true;
"hosts/*/profiles".functor.enable = true;
"profiles/*".functor.enable = true;
"profiles/sound/*".functor.enable = true;
"profiles/sound/pulseaudio/*".functor.enable = true;
"profiles/connectivity/*".functor.enable = true;
"profiles/gaming/*".functor.enable = true;
"profiles/gui/environments/*".functor.enable = true;
"users/*".functor.enable = true;
"home/*".functor.enable = true;
"home/gui/environments/*".functor.enable = true;
"home/apps/*".functor.enable = true;
"home/gaming/emulators/*".functor.enable = true;
"home/gaming/games/*".functor.enable = true;
"home/gaming/platforms/*".functor.enable = true;
"home/programming/languages/*".functor.enable = true;
"modules/nixos" = {
functor = {
enable = true;
external = [ ];
};
};
"modules/home" = {
functor = {
enable = true;
external = [ ];
};
};
};
};
}