From eae19f3c28503a8623b0fee10bfb0b3322122637 Mon Sep 17 00:00:00 2001 From: John Ericson Date: Wed, 31 Jan 2018 16:36:52 -0500 Subject: [PATCH] release-lib: Adapt to work with new meta.platforms `packagePlatforms` now filters `supportedSystems` with the new-style `meta.platforms`, rather than just plopping it in as is. --- pkgs/top-level/release-lib.nix | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/pkgs/top-level/release-lib.nix b/pkgs/top-level/release-lib.nix index 3e842f8b556..e377ca30f3a 100644 --- a/pkgs/top-level/release-lib.nix +++ b/pkgs/top-level/release-lib.nix @@ -98,7 +98,18 @@ rec { packagePlatforms = mapAttrs (name: value: let res = builtins.tryEval ( if isDerivation value then - value.meta.hydraPlatforms or (value.meta.platforms or [ "x86_64-linux" ]) + # TODO(@Ericson2314) deduplicate with `checkPlatform` in + # `pkgs/stdenv/generic/check-meta.nix`. + value.meta.hydraPlatforms or (let + raw = value.meta.platforms or [ "x86_64-linux" ]; + toPattern = x: if builtins.isString x + then { system = x; } + else { parsed = x; }; + uniform = map toPattern raw; + pred = hostPlatform: + lib.any (pat: lib.matchAttrs pat hostPlatform) uniform; + pred' = system: pred (lib.systems.elaborate { inherit system; }); + in lib.filter pred' supportedSystems) else if value.recurseForDerivations or false || value.recurseForRelease or false then packagePlatforms value else