forked from brendanhay/amazonka
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathflake.nix
153 lines (131 loc) · 4.53 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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
{
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixpkgs-unstable";
flake-utils.url = "github:numtide/flake-utils";
pre-commit-hooks = {
url = "github:cachix/pre-commit-hooks.nix";
inputs.nixpkgs.follows = "nixpkgs";
};
botocore = {
# Lock botocore until we fix https://github.com/issue/888
url = "github:boto/botocore/f14ab129706a99198d42eed78d75350ea61c48e9";
flake = false;
};
};
outputs = { self, nixpkgs, flake-utils, pre-commit-hooks, botocore }:
flake-utils.lib.eachDefaultSystem (system:
let
pre-commit = pre-commit-hooks.lib.${system}.run {
src = self;
hooks = {
cabal-fmt.enable = true;
nixpkgs-fmt.enable = true;
ormolu.enable = true;
shellcheck.enable = true;
shfmt.enable = true;
prettier = {
enable = true;
files = "\\.json$";
};
};
};
pkgs = import nixpkgs {
inherit system;
config.allowBroken = true;
};
# The ghc compiler version patch level will be the latest that is available in nixpkgs.
ghc810 = pkgs.haskell.packages."ghc810";
ghc90 = pkgs.haskell.packages."ghc90";
ghc92 = pkgs.haskell.packages."ghc92";
ghc94 = pkgs.haskell.packages."ghc94";
ghc96 = pkgs.haskell.packages."ghc96";
ghc98 = pkgs.haskell.packages."ghc98";
# The default ghc to use when entering `nix develop`.
ghcDefault = ghc94;
renameVersion = version: "ghc" + (pkgs.lib.replaceStrings [ "." ] [ "" ] version);
mkDevShell = hsPkgs: pkgs.mkShell {
name = "amazonka-${renameVersion hsPkgs.ghc.version}";
buildInputs = [
# Haskell Toolchain
hsPkgs.ghc
pkgs.cabal-install
# Package Dependencies
pkgs.gmp
pkgs.ncurses
pkgs.zlib
# Development Tools
pkgs.haskellPackages.cabal-fmt
pkgs.haskell-language-server
pkgs.hlint
pkgs.nixpkgs-fmt
pkgs.ormolu
# Releases
pkgs.gh
pkgs.parallel
];
shellHook = pre-commit.shellHook + ''
export BOTOCORE=${botocore.outPath}
echo "botocore: $BOTOCORE"
'';
};
amazonka-gen =
# Use ghc92 because we want hashable ==1.3.* for actual
# generation and the ghc-bignum dep is inside a conditional,
# so doJailbreak won't work.
#
# We need hashable-1.3 for generation because hashable >=1.4
# uses a different hashing algorithm which breaks things by
# causing the contents of `HashMap`s to be traversed in a
# slightly different order. This matters when `Ptr`s are
# used to resolve recursive shape references.
ghc92.developPackage {
root = ./gen;
overrides = _hsFinal: hsPrev: with pkgs.haskell.lib; {
data-fix = doJailbreak hsPrev.data-fix;
ede = dontCheck (hsPrev.callHackageDirect
{
pkg = "ede";
ver = "0.3.4.0";
sha256 = "sha256-bEYTVnVj/TigHgGiiMP/Yz3YE1gg2QYPCPrx6RrpSOo=";
}
{ });
hashable = hsPrev.callHackage "hashable" "1.3.5.0" { };
pandoc = dontHaddock hsPrev.pandoc;
semialign = doJailbreak hsPrev.semialign;
string-qq = dontCheck hsPrev.string-qq;
text-short = doJailbreak hsPrev.text-short;
these = doJailbreak hsPrev.these;
unordered-containers =
hsPrev.callHackage "unordered-containers" "0.2.19.1" { };
};
};
in
{
apps = {
gen = {
type = "app";
program = "${amazonka-gen}/bin/gen";
};
gen-configs = {
type = "app";
program = "${amazonka-gen}/bin/gen-configs";
};
};
checks = {
inherit pre-commit;
};
packages = {
default = amazonka-gen;
};
devShells = {
ghc810 = mkDevShell ghc810;
ghc90 = mkDevShell ghc90;
ghc92 = mkDevShell ghc92;
ghc94 = mkDevShell ghc94;
ghc96 = mkDevShell ghc96;
ghc98 = mkDevShell ghc98;
default = mkDevShell ghcDefault;
};
});
nixConfig.allow-import-from-derivation = "true";
}