diff options
author | makefu <github@syntax-fehler.de> | 2015-07-28 21:56:10 +0200 |
---|---|---|
committer | makefu <github@syntax-fehler.de> | 2015-07-28 21:56:10 +0200 |
commit | 41b5ec6ecd1cb2f38fc593ce545ef76188198318 (patch) | |
tree | 44f2f12060671dd0107d49a8fae2a5ac8728ccbb /tv/4lib/modules.nix | |
parent | 37799f2fbc5e2751755e4094460f8dbdfa6828a8 (diff) | |
parent | 074bbdf5b5c6d70d58f923f3a91b71bbf18abc9c (diff) |
Merge remote-tracking branch 'cd/user-toplevel' into user-toplevel
Diffstat (limited to 'tv/4lib/modules.nix')
-rw-r--r-- | tv/4lib/modules.nix | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/tv/4lib/modules.nix b/tv/4lib/modules.nix new file mode 100644 index 0000000..248e638 --- /dev/null +++ b/tv/4lib/modules.nix @@ -0,0 +1,21 @@ +let + pkgs = import <nixpkgs> {}; + inherit (pkgs.lib) concatMap hasAttr; +in rec { + + no-touch-args = { + config = throw "no-touch-args: can't touch config!"; + lib = throw "no-touch-args: can't touch lib!"; + pkgs = throw "no-touch-args: can't touch pkgs!"; + }; + + # list-imports : path -> [path] + # Return a module's transitive list of imports. + # XXX duplicates won't get eliminated from the result. + list-imports = path: + let module = import path no-touch-args; + imports = if hasAttr "imports" module + then concatMap list-imports module.imports + else []; + in [path] ++ imports; +} |