nix-config/flake.nix

73 lines
2 KiB
Nix
Raw Normal View History

{
description = "tacocat's nix configuration";
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable";
helix = {
url = "github:helix-editor/helix/master";
inputs.nixpkgs.follows = "nixpkgs";
};
home-manager = {
url = "github:nix-community/home-manager";
inputs.nixpkgs.follows = "nixpkgs";
};
};
# pass in the urls defined above
# the @ syntax stores the arguments in the inputs variable
outputs = inputs @ {
self,
nixpkgs,
home-manager,
2023-10-21 00:06:56 +00:00
helix,
}: let
system = "x86_64-linux";
pkgs = inputs.nixpkgs.legacyPackages.${system};
in {
# nixosConfigurations: define options for different systems
# desktop
nixosConfigurations."BICEP" = nixpkgs.lib.nixosSystem {
inherit system;
modules = [
./hosts/BICEP/configuration.nix
home-manager.nixosModules.home-manager
{
home-manager.useGlobalPkgs = true;
home-manager.users."tacocat" = ./users/tacocat/home.nix;
}
];
};
# laptop
nixosConfigurations."JWST" = nixpkgs.lib.nixosSystem {
inherit system;
modules = [
./hosts/JWST/configuration.nix
home-manager.nixosModules.home-manager
{
home-manager.useGlobalPkgs = true;
home-manager.users."tacocat" = ./users/tacocat/home.nix;
}
];
};
#homeConfigurations: define options for different users
homeConfigurations."tacocat" = inputs.home-manager.lib.homeManagerConfiguration {
inherit pkgs;
modules = [
2023-10-21 00:06:56 +00:00
./users/tacocat/home.nix
2023-10-21 00:49:53 +00:00
# ./users/tacocat/programs
# ./users/tacocat/shell
# ./users/tacocat/helix
# ./users/tacocat/emacs
# this is awful why are you doing it like this
];
};
2023-10-21 00:49:53 +00:00
extraSpecialArgs = { inherit inputs; }; # Pass flake inputs to our config
#outputs home-manager activation package for use on non-NixOS, i think?
packages.${system}."tacocat" = self.homeConfigurations."tacocat".activationPackage;
};
}