Skip to content

Commit

Permalink
each{,Default}SystemMap: accept binary functions
Browse files Browse the repository at this point in the history
related: numtide#78
  • Loading branch information
ilkecan committed Oct 24, 2023
1 parent 78b3158 commit cdb61a0
Showing 1 changed file with 9 additions and 8 deletions.
17 changes: 9 additions & 8 deletions lib.nix
Original file line number Diff line number Diff line change
Expand Up @@ -33,13 +33,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: attrs //
{
${key} = (attrs.${key} or { })
Expand All @@ -56,7 +50,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.
Expand Down Expand Up @@ -207,5 +202,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 cdb61a0

Please sign in to comment.