Bring an importable modulesPath back from the dead, in the only way I know
This commit is contained in:
parent
514a9fdf87
commit
b13cb54614
|
@ -17,6 +17,10 @@ rec {
|
||||||
evalModules) and the less declarative the module set is. */
|
evalModules) and the less declarative the module set is. */
|
||||||
evalModules = { modules
|
evalModules = { modules
|
||||||
, prefix ? []
|
, prefix ? []
|
||||||
|
, # This should only be used for special arguments that need to be evaluated
|
||||||
|
# when resolving module structure (like in imports). For everything else,
|
||||||
|
# there's _module.args.
|
||||||
|
specialArgs ? {}
|
||||||
, # This would be remove in the future, Prefer _module.args option instead.
|
, # This would be remove in the future, Prefer _module.args option instead.
|
||||||
args ? {}
|
args ? {}
|
||||||
, # This would be remove in the future, Prefer _module.check option instead.
|
, # This would be remove in the future, Prefer _module.check option instead.
|
||||||
|
@ -51,7 +55,7 @@ rec {
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
closed = closeModules (modules ++ [ internalModule ]) { inherit config options; lib = import ./.; };
|
closed = closeModules (modules ++ [ internalModule ]) (specialArgs // { inherit config options; lib = import ./.; });
|
||||||
|
|
||||||
# Note: the list of modules is reversed to maintain backward
|
# Note: the list of modules is reversed to maintain backward
|
||||||
# compatibility with the old module system. Not sure if this is
|
# compatibility with the old module system. Not sure if this is
|
||||||
|
@ -118,7 +122,7 @@ rec {
|
||||||
config = removeAttrs m ["key" "_file" "require" "imports"];
|
config = removeAttrs m ["key" "_file" "require" "imports"];
|
||||||
};
|
};
|
||||||
|
|
||||||
applyIfFunction = f: arg@{ config, options, lib }: if isFunction f then
|
applyIfFunction = f: arg@{ config, options, lib, ... }: if isFunction f then
|
||||||
let
|
let
|
||||||
# Module arguments are resolved in a strict manner when attribute set
|
# Module arguments are resolved in a strict manner when attribute set
|
||||||
# deconstruction is used. As the arguments are now defined with the
|
# deconstruction is used. As the arguments are now defined with the
|
||||||
|
|
|
@ -47,6 +47,7 @@ in rec {
|
||||||
inherit prefix check;
|
inherit prefix check;
|
||||||
modules = modules ++ extraModules ++ baseModules ++ [ pkgsModule ];
|
modules = modules ++ extraModules ++ baseModules ++ [ pkgsModule ];
|
||||||
args = extraArgs;
|
args = extraArgs;
|
||||||
|
specialArgs = { modulesPath = ../modules; };
|
||||||
}) config options;
|
}) config options;
|
||||||
|
|
||||||
# These are the extra arguments passed to every module. In
|
# These are the extra arguments passed to every module. In
|
||||||
|
|
|
@ -2,8 +2,6 @@
|
||||||
|
|
||||||
{
|
{
|
||||||
_module.args = {
|
_module.args = {
|
||||||
modulesPath = ../.;
|
|
||||||
|
|
||||||
pkgs_i686 = import ../../lib/nixpkgs.nix {
|
pkgs_i686 = import ../../lib/nixpkgs.nix {
|
||||||
system = "i686-linux";
|
system = "i686-linux";
|
||||||
config.allowUnfree = true;
|
config.allowUnfree = true;
|
||||||
|
|
Loading…
Reference in New Issue