-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathflake.nix
67 lines (63 loc) · 2.12 KB
/
flake.nix
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
{
description = "Home Manager configuration of sumner";
inputs = {
# Specify the source of Home Manager and Nixpkgs.
nixpkgs.url = "github:nixos/nixpkgs/nixpkgs-unstable";
home-manager = {
url = "github:nix-community/home-manager";
inputs.nixpkgs.follows = "nixpkgs";
};
flake-utils.url = "github:numtide/flake-utils";
declarative-cachix.url = "github:jonascarpay/declarative-cachix";
menucalc = {
url = "github:sumnerevans/menu-calc";
inputs.nixpkgs.follows = "nixpkgs";
};
mdf = {
url = "github:sumnerevans/mdf";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs = { self, nixpkgs, home-manager, declarative-cachix, flake-utils
, menucalc, mdf }:
let
system = "x86_64-linux";
mkConfig = hostModule:
home-manager.lib.homeManagerConfiguration {
pkgs = import nixpkgs {
inherit system;
config = {
allowUnfree = true;
permittedInsecurePackages = [ "olm-3.2.16" ];
};
overlays = [
(final: prev: { inherit (menucalc.packages.${system}) menucalc; })
(final: prev: { inherit (mdf.packages.${system}) mdf; })
];
};
modules = [ ./home.nix hostModule ];
extraSpecialArgs = { inherit declarative-cachix; };
};
in {
homeConfigurations."tatooine" =
mkConfig ./host-configurations/tatooine.nix;
homeConfigurations."coruscant" = mkConfig ./host-configurations/coruscant;
homeConfigurations."scarif" = mkConfig ./host-configurations/scarif.nix;
homeConfigurations."mustafar" =
mkConfig ./host-configurations/mustafar.nix;
homeConfigurations."automattic" =
mkConfig ./host-configurations/automattic.nix;
} // (flake-utils.lib.eachDefaultSystem (system:
let pkgs = import nixpkgs { system = system; };
in {
devShells.default = pkgs.mkShell {
packages = with pkgs; [
black
cargo
git-crypt
nixfmt-classic
pre-commit
];
};
}));
}