48 lines
1.2 KiB
Nix
48 lines
1.2 KiB
Nix
|
# This file works in tandem with ../../ci/eval/default.nix
|
||
|
# It turns ./release-outpaths.nix into chunks of a fixed size
|
||
|
{
|
||
|
lib ? import ../../lib,
|
||
|
path ? ../..,
|
||
|
# The file containing all available attribute paths, which are split into chunks here
|
||
|
attrpathFile,
|
||
|
chunkSize,
|
||
|
myChunk,
|
||
|
checkMeta,
|
||
|
includeBroken,
|
||
|
systems,
|
||
|
}:
|
||
|
|
||
|
let
|
||
|
attrpaths = lib.importJSON attrpathFile;
|
||
|
myAttrpaths = lib.sublist (chunkSize * myChunk) chunkSize attrpaths;
|
||
|
|
||
|
unfiltered = import ./release-outpaths.nix {
|
||
|
inherit path;
|
||
|
inherit checkMeta includeBroken systems;
|
||
|
};
|
||
|
|
||
|
# Turns the unfiltered recursive attribute set into one that is limited to myAttrpaths
|
||
|
filtered =
|
||
|
let
|
||
|
recurse =
|
||
|
index: paths: attrs:
|
||
|
lib.mapAttrs (
|
||
|
name: values:
|
||
|
if attrs ? ${name} then
|
||
|
if lib.any (value: lib.length value <= index + 1) values then
|
||
|
attrs.${name}
|
||
|
else
|
||
|
recurse (index + 1) values attrs.${name}
|
||
|
# Make sure nix-env recurses as well
|
||
|
// {
|
||
|
recurseForDerivations = true;
|
||
|
}
|
||
|
else
|
||
|
null
|
||
|
) (lib.groupBy (a: lib.elemAt a index) paths);
|
||
|
in
|
||
|
recurse 0 myAttrpaths unfiltered;
|
||
|
|
||
|
in
|
||
|
filtered
|