diff --git a/default.nix b/default.nix index 45e43c18e6d..df69ee4c3e2 100644 --- a/default.nix +++ b/default.nix @@ -9,29 +9,14 @@ let nixpkgs = fromEnv "NIXPKGS" /etc/nixos/nixpkgs; pkgs = import nixpkgs {system = builtins.currentSystem;}; - - configComponents = [ - configuration - (import ./system/options.nix) - ]; - # Make a configuration object from which we can retrieve option - # values. - config = - pkgs.lib.fixOptionSets - pkgs.lib.mergeOptionSets - pkgs configComponents; + inherit + (import ./lib/eval-config.nix {inherit configuration pkgs;}) + config optionDeclarations; - optionDeclarations = - pkgs.lib.fixOptionSetsFun - pkgs.lib.filterOptionSets - pkgs configComponents - config; - in { - # Optionally check wether all config values have corresponding # option declarations. system = pkgs.checker config.system.build.system diff --git a/lib/eval-config.nix b/lib/eval-config.nix new file mode 100644 index 00000000000..e1cf7ac3cf6 --- /dev/null +++ b/lib/eval-config.nix @@ -0,0 +1,23 @@ +# From an end-user configuration file (`configuration'), build a NixOS +# configuration object (`config') from which we can retrieve option +# values. + +{configuration, pkgs}: + +rec { + configComponents = [ + configuration + (import ../system/options.nix) + ]; + + config = + pkgs.lib.fixOptionSets + pkgs.lib.mergeOptionSets + pkgs configComponents; + + optionDeclarations = + pkgs.lib.fixOptionSetsFun + pkgs.lib.filterOptionSets + pkgs configComponents + config; +}