forked from NixOS/nixpkgs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
release-unfree-redistributable.nix
122 lines (101 loc) · 3.42 KB
/
release-unfree-redistributable.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
/*
Nixpkgs unfree+redistributable packages.
NOTE: This file is used by the sister nix-community project.
The official Hydra instance only builds and provides binary caches for free
packages (as in OSI-approved).
Some unfree packages such as MongoDB, ZeroTier, ... take a while to be
built. While their license is not free, they allow redistribution of
build artefacts.
The sister project nix-community will build and distribute those packages
for a subset of the channels to <https://nix-community.cachix.org>.
See also:
* <https://hydra.nix-community.org/jobset/nixpkgs/unfree-redistributable>
* <https://github.com/nix-community/infra/pull/1406>
Test for example like this:
$ hydra-eval-jobs pkgs/top-level/release-unfree-redistributable.nix -I .
*/
{
# The platforms for which we build Nixpkgs.
supportedSystems ? [
"x86_64-linux"
"aarch64-linux"
],
# Attributes passed to nixpkgs.
nixpkgsArgs ? {
config = {
allowAliases = false;
allowUnfree = true;
cudaSupport = true;
inHydra = true;
};
},
# We only build the full package set on infrequently releasing channels.
full ? false,
}:
let
release-lib = import ./release-lib.nix {
inherit supportedSystems nixpkgsArgs;
};
inherit (release-lib)
lib
mapTestOn
pkgs
;
# similar to release-lib.packagePlatforms, but also includes some condition for which package to pick
packagesWith =
prefix: cond:
lib.mapAttrs (
name: value:
let
attrPath = if prefix == "" then name else "${prefix}.${name}";
res = builtins.tryEval (
if lib.isDerivation value then
lib.optionals (cond attrPath value) (
# logic copied from release-lib packagePlatforms
value.meta.hydraPlatforms
or (lib.subtractLists (value.meta.badPlatforms or [ ]) (value.meta.platforms or [ "x86_64-linux" ]))
)
else if
value.recurseForDerivations or false
|| value.recurseForRelease or false
|| value.__recurseIntoDerivationForReleaseJobs or false
then
# Recurse
packagesWith attrPath cond value
else
[ ]
);
in
lib.optionals res.success res.value
);
# Unfree is any license not OSI-approved.
isUnfree = pkg: lib.lists.any (l: !(l.free or true)) (lib.lists.toList (pkg.meta.license or [ ]));
# Whenever the license allows re-distribution of the binaries
isRedistributable =
pkg: lib.lists.any (l: l.redistributable or false) (lib.lists.toList (pkg.meta.license or [ ]));
isSource =
pkg: !lib.lists.any (x: !(x.isSource)) (lib.lists.toList (pkg.meta.sourceProvenance or [ ]));
isNotLinuxKernel =
attrPath: !(lib.hasPrefix "linuxKernel" attrPath || lib.hasPrefix "linuxPackages" attrPath);
# This is handled by release-cuda.nix
isNotCudaPackage = attrPath: !(lib.hasPrefix "cuda" attrPath);
canSubstituteSrc =
pkg:
# requireFile don't allow using substituters and are therefor skipped
pkg.src.allowSubstitutes or true;
cond =
attrPath: pkg:
(isUnfree pkg)
&& (isRedistributable pkg)
&& (isSource pkg)
&& (canSubstituteSrc pkg)
&& (
full
||
# We only build these heavy packages on releases
((isNotCudaPackage attrPath) && (isNotLinuxKernel attrPath))
);
packages = packagesWith "" cond pkgs;
jobs = mapTestOn packages;
in
jobs