Skip to content

Commit eac2f2b

Browse files
committed
modernize
1 parent d549cc1 commit eac2f2b

15 files changed

+386
-177
lines changed

.github/workflows/test.yml

-37
This file was deleted.

.gitignore

+2
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,2 @@
1+
result
2+
result-*

.stylish-haskell.yaml

-22
This file was deleted.

configurations/ghc-8.10.project

-7
This file was deleted.

configurations/ghc-9.0.project

-4
This file was deleted.

configurations/ghc-9.2.project

-4
This file was deleted.

default.nix

+44
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,44 @@
1+
let
2+
3+
sources = import ./nix/sources.nix;
4+
nixos-22-05 = import sources."nixos-22.05" {};
5+
nixos-22-11 = import sources."nixos-22.11" {};
6+
inherit (nixos-22-11) haskell lib symlinkJoin;
7+
inherit (lib) fold composeExtensions concatMap attrValues;
8+
9+
combineOverrides = old:
10+
fold composeExtensions (old.overrides or (_: _: { }));
11+
12+
sourceOverrides = haskell.lib.packageSourceOverrides {
13+
unfork = ./unfork;
14+
};
15+
16+
depOverrides = new: old: {
17+
# ascii-case = new.callPackage ./nix/ascii-case-1.0.1.0.nix {};
18+
};
19+
20+
ghc."8.10" = nixos-22-05.haskell.packages.ghc8107.override (old: {
21+
overrides = combineOverrides old [ sourceOverrides depOverrides ];
22+
});
23+
24+
ghc."9.0" = nixos-22-11.haskell.packages.ghc90.override (old: {
25+
overrides = combineOverrides old [ sourceOverrides depOverrides ];
26+
});
27+
28+
ghc."9.2" = nixos-22-11.haskell.packages.ghc92.override (old: {
29+
overrides = combineOverrides old [ sourceOverrides depOverrides ];
30+
});
31+
32+
ghc."9.4" = nixos-22-11.haskell.packages.ghc94.override (old: {
33+
overrides = combineOverrides old [ sourceOverrides depOverrides ];
34+
});
35+
36+
in
37+
38+
symlinkJoin {
39+
name = "unfork";
40+
paths = concatMap (x: [x.unfork]) (attrValues ghc);
41+
} // {
42+
inherit ghc;
43+
pkgs = nixos-22-11;
44+
}

hie.yaml

-2
This file was deleted.

nix/ascii-case-1.0.1.0.nix

+11
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,11 @@
1+
{ mkDerivation, ascii-char, base, hashable, lib }:
2+
mkDerivation {
3+
pname = "ascii-case";
4+
version = "1.0.1.0";
5+
sha256 = "906becac5d9fea928333feeedd7e78d9bd663cc5faf80094ff92ef4f1edc1743";
6+
libraryHaskellDepends = [ ascii-char base hashable ];
7+
testHaskellDepends = [ ascii-char base ];
8+
homepage = "https://github.com/typeclasses/ascii";
9+
description = "ASCII letter case";
10+
license = lib.licenses.asl20;
11+
}

nix/sources.json

+26
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,26 @@
1+
{
2+
"nixos-22.05": {
3+
"branch": "nixos-22.05",
4+
"description": "Nix Packages collection",
5+
"homepage": "",
6+
"owner": "NixOS",
7+
"repo": "nixpkgs",
8+
"rev": "5cfefb9600de34ce9b8015be80948e5ce7458816",
9+
"sha256": "14vwma7lvx0vmq1gk2fp1f6k9s0009awb58z0dlv00rxzyyw02rc",
10+
"type": "tarball",
11+
"url": "https://github.com/NixOS/nixpkgs/archive/5cfefb9600de34ce9b8015be80948e5ce7458816.tar.gz",
12+
"url_template": "https://github.com/<owner>/<repo>/archive/<rev>.tar.gz"
13+
},
14+
"nixos-22.11": {
15+
"branch": "nixos-22.11",
16+
"description": "Nix Packages collection",
17+
"homepage": "",
18+
"owner": "NixOS",
19+
"repo": "nixpkgs",
20+
"rev": "9898811c658d39b2692d0ab744377e02fd85d08b",
21+
"sha256": "0vk147ivb029h5pmg6nb127nvfgmy728nlnzk7x152dl1b68jmx0",
22+
"type": "tarball",
23+
"url": "https://github.com/NixOS/nixpkgs/archive/9898811c658d39b2692d0ab744377e02fd85d08b.tar.gz",
24+
"url_template": "https://github.com/<owner>/<repo>/archive/<rev>.tar.gz"
25+
}
26+
}

nix/sources.nix

+194
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,194 @@
1+
# This file has been generated by Niv.
2+
3+
let
4+
5+
#
6+
# The fetchers. fetch_<type> fetches specs of type <type>.
7+
#
8+
9+
fetch_file = pkgs: name: spec:
10+
let
11+
name' = sanitizeName name + "-src";
12+
in
13+
if spec.builtin or true then
14+
builtins_fetchurl { inherit (spec) url sha256; name = name'; }
15+
else
16+
pkgs.fetchurl { inherit (spec) url sha256; name = name'; };
17+
18+
fetch_tarball = pkgs: name: spec:
19+
let
20+
name' = sanitizeName name + "-src";
21+
in
22+
if spec.builtin or true then
23+
builtins_fetchTarball { name = name'; inherit (spec) url sha256; }
24+
else
25+
pkgs.fetchzip { name = name'; inherit (spec) url sha256; };
26+
27+
fetch_git = name: spec:
28+
let
29+
ref =
30+
if spec ? ref then spec.ref else
31+
if spec ? branch then "refs/heads/${spec.branch}" else
32+
if spec ? tag then "refs/tags/${spec.tag}" else
33+
abort "In git source '${name}': Please specify `ref`, `tag` or `branch`!";
34+
submodules = if spec ? submodules then spec.submodules else false;
35+
submoduleArg =
36+
let
37+
nixSupportsSubmodules = builtins.compareVersions builtins.nixVersion "2.4" >= 0;
38+
emptyArgWithWarning =
39+
if submodules == true
40+
then
41+
builtins.trace
42+
(
43+
"The niv input \"${name}\" uses submodules "
44+
+ "but your nix's (${builtins.nixVersion}) builtins.fetchGit "
45+
+ "does not support them"
46+
)
47+
{}
48+
else {};
49+
in
50+
if nixSupportsSubmodules
51+
then { inherit submodules; }
52+
else emptyArgWithWarning;
53+
in
54+
builtins.fetchGit
55+
({ url = spec.repo; inherit (spec) rev; inherit ref; } // submoduleArg);
56+
57+
fetch_local = spec: spec.path;
58+
59+
fetch_builtin-tarball = name: throw
60+
''[${name}] The niv type "builtin-tarball" is deprecated. You should instead use `builtin = true`.
61+
$ niv modify ${name} -a type=tarball -a builtin=true'';
62+
63+
fetch_builtin-url = name: throw
64+
''[${name}] The niv type "builtin-url" will soon be deprecated. You should instead use `builtin = true`.
65+
$ niv modify ${name} -a type=file -a builtin=true'';
66+
67+
#
68+
# Various helpers
69+
#
70+
71+
# https://github.com/NixOS/nixpkgs/pull/83241/files#diff-c6f540a4f3bfa4b0e8b6bafd4cd54e8bR695
72+
sanitizeName = name:
73+
(
74+
concatMapStrings (s: if builtins.isList s then "-" else s)
75+
(
76+
builtins.split "[^[:alnum:]+._?=-]+"
77+
((x: builtins.elemAt (builtins.match "\\.*(.*)" x) 0) name)
78+
)
79+
);
80+
81+
# The set of packages used when specs are fetched using non-builtins.
82+
mkPkgs = sources: system:
83+
let
84+
sourcesNixpkgs =
85+
import (builtins_fetchTarball { inherit (sources.nixpkgs) url sha256; }) { inherit system; };
86+
hasNixpkgsPath = builtins.any (x: x.prefix == "nixpkgs") builtins.nixPath;
87+
hasThisAsNixpkgsPath = <nixpkgs> == ./.;
88+
in
89+
if builtins.hasAttr "nixpkgs" sources
90+
then sourcesNixpkgs
91+
else if hasNixpkgsPath && ! hasThisAsNixpkgsPath then
92+
import <nixpkgs> {}
93+
else
94+
abort
95+
''
96+
Please specify either <nixpkgs> (through -I or NIX_PATH=nixpkgs=...) or
97+
add a package called "nixpkgs" to your sources.json.
98+
'';
99+
100+
# The actual fetching function.
101+
fetch = pkgs: name: spec:
102+
103+
if ! builtins.hasAttr "type" spec then
104+
abort "ERROR: niv spec ${name} does not have a 'type' attribute"
105+
else if spec.type == "file" then fetch_file pkgs name spec
106+
else if spec.type == "tarball" then fetch_tarball pkgs name spec
107+
else if spec.type == "git" then fetch_git name spec
108+
else if spec.type == "local" then fetch_local spec
109+
else if spec.type == "builtin-tarball" then fetch_builtin-tarball name
110+
else if spec.type == "builtin-url" then fetch_builtin-url name
111+
else
112+
abort "ERROR: niv spec ${name} has unknown type ${builtins.toJSON spec.type}";
113+
114+
# If the environment variable NIV_OVERRIDE_${name} is set, then use
115+
# the path directly as opposed to the fetched source.
116+
replace = name: drv:
117+
let
118+
saneName = stringAsChars (c: if isNull (builtins.match "[a-zA-Z0-9]" c) then "_" else c) name;
119+
ersatz = builtins.getEnv "NIV_OVERRIDE_${saneName}";
120+
in
121+
if ersatz == "" then drv else
122+
# this turns the string into an actual Nix path (for both absolute and
123+
# relative paths)
124+
if builtins.substring 0 1 ersatz == "/" then /. + ersatz else /. + builtins.getEnv "PWD" + "/${ersatz}";
125+
126+
# Ports of functions for older nix versions
127+
128+
# a Nix version of mapAttrs if the built-in doesn't exist
129+
mapAttrs = builtins.mapAttrs or (
130+
f: set: with builtins;
131+
listToAttrs (map (attr: { name = attr; value = f attr set.${attr}; }) (attrNames set))
132+
);
133+
134+
# https://github.com/NixOS/nixpkgs/blob/0258808f5744ca980b9a1f24fe0b1e6f0fecee9c/lib/lists.nix#L295
135+
range = first: last: if first > last then [] else builtins.genList (n: first + n) (last - first + 1);
136+
137+
# https://github.com/NixOS/nixpkgs/blob/0258808f5744ca980b9a1f24fe0b1e6f0fecee9c/lib/strings.nix#L257
138+
stringToCharacters = s: map (p: builtins.substring p 1 s) (range 0 (builtins.stringLength s - 1));
139+
140+
# https://github.com/NixOS/nixpkgs/blob/0258808f5744ca980b9a1f24fe0b1e6f0fecee9c/lib/strings.nix#L269
141+
stringAsChars = f: s: concatStrings (map f (stringToCharacters s));
142+
concatMapStrings = f: list: concatStrings (map f list);
143+
concatStrings = builtins.concatStringsSep "";
144+
145+
# https://github.com/NixOS/nixpkgs/blob/8a9f58a375c401b96da862d969f66429def1d118/lib/attrsets.nix#L331
146+
optionalAttrs = cond: as: if cond then as else {};
147+
148+
# fetchTarball version that is compatible between all the versions of Nix
149+
builtins_fetchTarball = { url, name ? null, sha256 }@attrs:
150+
let
151+
inherit (builtins) lessThan nixVersion fetchTarball;
152+
in
153+
if lessThan nixVersion "1.12" then
154+
fetchTarball ({ inherit url; } // (optionalAttrs (!isNull name) { inherit name; }))
155+
else
156+
fetchTarball attrs;
157+
158+
# fetchurl version that is compatible between all the versions of Nix
159+
builtins_fetchurl = { url, name ? null, sha256 }@attrs:
160+
let
161+
inherit (builtins) lessThan nixVersion fetchurl;
162+
in
163+
if lessThan nixVersion "1.12" then
164+
fetchurl ({ inherit url; } // (optionalAttrs (!isNull name) { inherit name; }))
165+
else
166+
fetchurl attrs;
167+
168+
# Create the final "sources" from the config
169+
mkSources = config:
170+
mapAttrs (
171+
name: spec:
172+
if builtins.hasAttr "outPath" spec
173+
then abort
174+
"The values in sources.json should not have an 'outPath' attribute"
175+
else
176+
spec // { outPath = replace name (fetch config.pkgs name spec); }
177+
) config.sources;
178+
179+
# The "config" used by the fetchers
180+
mkConfig =
181+
{ sourcesFile ? if builtins.pathExists ./sources.json then ./sources.json else null
182+
, sources ? if isNull sourcesFile then {} else builtins.fromJSON (builtins.readFile sourcesFile)
183+
, system ? builtins.currentSystem
184+
, pkgs ? mkPkgs sources system
185+
}: rec {
186+
# The sources, i.e. the attribute set of spec name to spec
187+
inherit sources;
188+
189+
# The "pkgs" (evaluated nixpkgs) to use for e.g. non-builtin fetchers
190+
inherit pkgs;
191+
};
192+
193+
in
194+
mkSources (mkConfig {}) // { __functor = _: settings: mkSources (mkConfig settings); }

0 commit comments

Comments
 (0)