Add support for a new module syntax.

Introduce optional argument to optionSet options.

svn path=/nixpkgs/trunk/; revision=15935
This commit is contained in:
Nicolas Pierron 2009-06-11 16:03:26 +00:00
parent 2b68672d1c
commit b32002c3a3
1 changed files with 65 additions and 8 deletions

View File

@ -70,14 +70,21 @@ rec {
handleOptionSets = opt:
if decl ? type && decl.type.hasOptions then
opt // {
merge = list:
decl.type.iter
(path: opts: recurseInto path (decl.options ++ [opts]))
opt.name
(opt.merge list);
options = recurseInto (decl.type.docPath opt.name) decl.options;
}
let
optionConfig = opts: config:
map (f: applyIfFunction f config)
(decl.options ++ [opts]);
in
opt // {
merge = list:
decl.type.iter
(path: opts:
fixMergeFun (recurseInto path) (optionConfig opts)
)
opt.name
(opt.merge list);
options = recurseInto (decl.type.docPath opt.name) decl.options;
}
else
opt;
in
@ -361,6 +368,56 @@ rec {
|| builtins.isList x
);
applyIfFunction = f: arg:
if builtins.isFunction f then
f arg
else
f;
moduleClosure = initModules: args:
let
moduleImport = path:
(applyIfFunction (import path) args) // {
# used by generic closure to avoid duplicated imports.
key = path;
};
in
builtins.genericClosure {
startSet = map moduleImport initModules;
operator = m:
map moduleImport (attrByPath ["imports"] [] m);
};
selectDeclsAndDefs = modules:
lib.concatMap (m:
attrByPath ["options"] [] m
++ attrByPath ["config"] [] m
) modules;
fixMergeFun = merge: optFun:
lib.fix (config:
merge (
# Delay top-level properties like mkIf
map delayProperties (
# generate the list of option sets.
optFun config
)
)
);
fixMergeModules = merge: initModules: {...}@args:
fixMergeFun (config:
selectDeclsAndDefs (
moduleClosure initModules (args // { inherit config; })
)
);
fixModulesConfig = initModules: {...}@args:
fixMergeModules (mergeOptionSets "") initModules args;
fixOptionsConfig = initModules: {...}@args:
fixMergeModules (filterOptionSets "") initModules args;
# Evaluate a list of option sets that would be merged with the
# function "merge" which expects two arguments. The attribute named