-
Notifications
You must be signed in to change notification settings - Fork 95
/
flake.nix
93 lines (85 loc) · 3.47 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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
{
description = "Chainweb";
inputs = {
hackage = {
url = "github:input-output-hk/hackage.nix";
flake = false;
};
hs-nix-infra = {
url = "github:kadena-io/hs-nix-infra";
inputs.hackage.follows = "hackage";
};
flake-utils.url = "github:numtide/flake-utils";
nix-filter.url = "github:numtide/nix-filter";
empty = {
url = "github:kadena-io/empty";
flake = false;
};
# By default we use the pact specified in the cabal.project
pact.follows = "empty";
};
nixConfig = {
extra-substituters = "https://nixcache.chainweb.com https://cache.iog.io";
trusted-public-keys = "nixcache.chainweb.com:FVN503ABX9F8x8K0ptnc99XEz5SaA4Sks6kNcZn2pBY= hydra.iohk.io:f/Ea+s+dFdN+3Y/G+FDgSq+a5NEWhJGzdjvKNGv0/EQ= cache.nixos.org-1:6NCHdD59X431o0gWypbMrAURkbJ16ZPMQFGspcDShjY=";
};
outputs = inputs@{ self, hs-nix-infra, flake-utils, nix-filter, ... }:
flake-utils.lib.eachSystem
[ "x86_64-linux" "x86_64-darwin"
"aarch64-linux" "aarch64-darwin" ] (system:
let
inherit (hs-nix-infra) nixpkgs haskellNix;
# The pactInput is non-null only if the pact input was overridden
pactInput = if inputs.pact.outPath != inputs.empty.outPath then inputs.pact else null;
basePkgs = hs-nix-infra.nixpkgs.legacyPackages.${system};
pkgs = import nixpkgs {
inherit system;
inherit (haskellNix) config;
overlays = [ haskellNix.overlay ];
};
mkDefaultNix = {
pact ? pactInput,
enablePactBuildTool ? false,
}: import ./default.nix {
inherit pkgs nix-filter pact enablePactBuildTool;
flakePath = self.outPath;
};
defaultNix = mkDefaultNix {};
flake = defaultNix.flake;
mkRecursive = { pact ? pactInput }: with hs-nix-infra.lib.recursive system;
let args = if pact == null then "{}" else "{ pact = builtins.storePath ${pact}; }";
recursive = wrapRecursiveWithMeta "chainweb-node" ''
(${wrapFlake self}.lib.${system}.mkDefaultNix ${args}).default
'';
in recursive // { pact = defaultNix.pactFromCached pkgs-rec pact recursive.cached; };
executables = defaultNix.default;
# This package depends on other packages at buildtime, but its output does not
# depend on them. This way, we don't have to download the entire closure to verify
# that those packages build.
mkCheck = name: package: pkgs.runCommand ("check-"+name) {} ''
echo ${name}: ${package}
echo works > $out
'';
in {
packages = {
default = executables;
# This package is equivalent to the default package, but it offloads the
# evaluation of the haskellNix project to a recursive nix-build. If you expect to
# find this package in your nix store or a binary cache, using this package will
# significantly reduce your nix eval times and the amount of data you download.
recursive = mkRecursive {};
check = pkgs.runCommand "check" {} ''
echo ${mkCheck "chainweb" executables}
echo ${mkCheck "devShell" flake.devShell}
echo works > $out
'';
};
# Used by nix develop
devShell = flake.devShell;
# Not used by standard Nix tooling, but could be useful for downstream users
project = defaultNix.chainweb;
lib = {
inherit mkDefaultNix mkRecursive;
mkChainwebProject = args: (mkDefaultNix args).chainweb;
};
});
}