From 02677481aeaf1e861b9b3456a9086c34a51550d7 Mon Sep 17 00:00:00 2001 From: Nicolas Pierron Date: Wed, 27 Apr 2011 18:41:37 +0000 Subject: [PATCH] modules (moduleClosure): use imap instead of map to produce uniq keys for the genericClosure. svn path=/nixpkgs/trunk/; revision=27014 --- pkgs/lib/modules.nix | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) diff --git a/pkgs/lib/modules.nix b/pkgs/lib/modules.nix index 08c26e72f72e..8ecb04156e78 100644 --- a/pkgs/lib/modules.nix +++ b/pkgs/lib/modules.nix @@ -80,19 +80,29 @@ rec { moduleClosure = initModules: args: let - moduleImport = m: + moduleImport = origin: index: m: let m' = applyIfFunction (importIfPath m) args; in (unifyModuleSyntax m') // { # used by generic closure to avoid duplicated imports. - key = if isPath m then m else if m' ? key then m'.key else ""; + key = + if isPath m then m + else if m' ? key then m'.key + else newModuleName origin index; }; getImports = m: attrByPath ["imports"] [] m; + newModuleName = origin: index: + "${origin.key}:"; + + topLevel = { + key = ""; + }; + in (lazyGenericClosure { - startSet = map moduleImport initModules; - operator = m: map moduleImport (getImports m); + startSet = imap (moduleImport topLevel) initModules; + operator = m: imap (moduleImport m) (getImports m); }); selectDeclsAndDefs = modules: