Skip to content

Commit

Permalink
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
each{,Default}SystemMap: accept binary functions
Browse files Browse the repository at this point in the history
Related: numtide#78
ilkecan committed Sep 7, 2022
1 parent 19d1236 commit f651edc
Showing 1 changed file with 9 additions and 8 deletions.
17 changes: 9 additions & 8 deletions default.nix
Original file line number Diff line number Diff line change
@@ -125,13 +125,7 @@ let
# Merge together the outputs for all systems.
op = attrs: system:
let
ret =
let
retOrFunc = f system;
in
if builtins.isFunction retOrFunc
then retOrFunc ret
else retOrFunc;
ret = maybeFix (f system);

op = attrs: key:
let
@@ -155,7 +149,8 @@ let
eachDefaultSystemMap = eachSystemMap defaultSystems;

# Builds a map from <attr>=value to <system>.<attr> = value.
eachSystemMap = systems: f: builtins.listToAttrs (builtins.map (system: { name = system; value = f system; }) systems);
eachSystemMap = systems: f:
builtins.listToAttrs (builtins.map (system: { name = system; value = maybeFix (f system); }) systems);

# Nix flakes insists on having a flat attribute set of derivations in
# various places like the `packages` and `checks` attributes.
@@ -232,5 +227,11 @@ let
system
;
};

maybeFix = arg:
let
fix = f: let x = f x; in x;
in
if builtins.isFunction arg then fix arg else arg;
in
lib

0 comments on commit f651edc

Please sign in to comment.