default out: simplify namespace loader

This commit is contained in:
tv 2015-10-17 06:16:56 +02:00
parent 421bf2ac08
commit ad21810424
1 changed files with 9 additions and 17 deletions

View File

@ -23,29 +23,23 @@ let
out =
{ inherit (eval {}) pkgs; } //
lib.mapAttrs (_: builtins.getAttr "main")
(lib.filterAttrs (_: builtins.hasAttr "main")
(lib.mapAttrs
(k: v:
if lib.hasPrefix "." k || v != "directory" then
{}
else if builtins.pathExists (./. + "/${k}/default.nix") then
{ main = import (./. + "/${k}"); }
else if builtins.pathExists (./. + "/${k}/1systems") then
{ main = mk-namespace (./. + "/${k}"); }
else
{})
(builtins.readDir ./.)));
lib.mapAttrs
(name: _:
if builtins.pathExists (./. + "/${name}/default.nix")
then import (./. + "/${name}")
else import-1systems (./. + "/${name}/1systems"))
(lib.filterAttrs
(n: t: !lib.hasPrefix "." n && t == "directory")
(builtins.readDir ./.));
eval = path: import <nixpkgs/nixos/lib/eval-config.nix> {
system = builtins.currentSystem;
modules = [
stockholm
path
];
};
mk-namespace = path: mapNixDir mk-system (path + "/1systems");
import-1systems = path: lib.mapAttrs (_: mk-system) (nixDir path);
mk-system = path: rec {
inherit (eval path) config options;
@ -53,8 +47,6 @@ let
fetch = import ./krebs/0tools/fetch.nix { inherit config lib; };
};
mapNixDir = f: path: lib.mapAttrs (_: f) (nixDir path);
nixDir = path:
builtins.listToAttrs
(catMaybes