3
0
Fork 0
forked from mirrors/nixpkgs

Add option type for a submodule with extra arguments

This commit is contained in:
Shea Levy 2014-02-11 14:39:46 -05:00
parent ca1c5cfa8f
commit 8764758044

View file

@ -176,7 +176,7 @@ rec {
getSubOptions = elemType.getSubOptions;
};
submodule = opts:
submoduleWithExtraArgs = extraArgs: opts:
let
opts' = toList opts;
inherit (import ./modules.nix) evalModules;
@ -188,13 +188,16 @@ rec {
let
coerce = def: if isFunction def then def else { config = def; };
modules = opts' ++ map (def: { _file = def.file; imports = [(coerce def.value)]; }) defs;
in (evalModules { inherit modules; args.name = last loc; prefix = loc; }).config;
args = extraArgs // { name = last loc; };
in (evalModules { inherit modules args; prefix = loc; }).config;
getSubOptions = prefix: (evalModules
{ modules = opts'; inherit prefix;
# FIXME: hack to get shit to evaluate.
args = { name = ""; }; }).options;
args = extraArgs // { name = ""; }; }).options;
};
submodule = submoduleWithExtraArgs {};
nixosSubmodule = nixos: args: mkOptionType rec {
name = "submodule containing a NixOS config";
check = x: isAttrs x || isFunction x;