Merge pull request #5415 from nbp/nixos-options-submodules

nixos-option: Handle submodules
This commit is contained in:
Nicolas B. Pierron 2014-12-21 15:10:46 -08:00
commit e4fb4168fc
1 changed files with 76 additions and 12 deletions

View File

@ -83,6 +83,68 @@ EOF
fi fi
} }
header="let
nixos = import <nixpkgs/nixos> {};
nixpkgs = import <nixpkgs> {};
in with nixpkgs.lib;
"
# This function is used for converting the option definition path given by
# the user into accessors for reaching the definition and the declaration
# corresponding to this option.
generateAccessors(){
if result=$(evalNix --strict --show-trace <<EOF
$header
let
path = "${option:+$option}";
pathList = splitString "." path;
walkOptions = attrsNames: result:
if attrsNames == [] then
result
else
let name = head attrsNames; rest = tail attrsNames; in
if isOption result.options then
walkOptions rest {
options = result.options.type.getSubOptions "";
opt = ''(\${result.opt}.type.getSubOptions "")'';
cfg = ''\${result.cfg}."\${name}"'';
}
else
walkOptions rest {
options = result.options.\${name};
opt = ''\${result.opt}."\${name}"'';
cfg = ''\${result.cfg}."\${name}"'';
}
;
walkResult = (if path == "" then x: x else walkOptions pathList) {
options = nixos.options;
opt = ''nixos.options'';
cfg = ''nixos.config'';
};
in
''let option = \${walkResult.opt}; config = \${walkResult.cfg}; in''
EOF
)
then
echo $result
else
# In case of error we want to ignore the error message roduced by the
# script above, as it is iterating over each attribute, which does not
# produce a nice error message. The following code is a fallback
# solution which is cause a nicer error message in the next
# evaluation.
echo "\"let option = nixos.options${option:+.$option}; config = nixos.config${option:+.$option}; in\""
fi
}
header="$header
$(eval echo $(generateAccessors))
"
evalAttr(){ evalAttr(){
local prefix="$1" local prefix="$1"
local strict="$2" local strict="$2"
@ -92,10 +154,10 @@ evalAttr(){
test -n "$strict" && strict=true test -n "$strict" && strict=true
evalNix ${strict:+--strict} <<EOF evalNix ${strict:+--strict} <<EOF
$header
let let
reach = attrs: attrs${option:+.$option}${suffix:+.$suffix}; value = $prefix${suffix:+.$suffix};
nixos = import <nixos> {};
nixpkgs = import <nixpkgs> {};
strict = ${strict:-false}; strict = ${strict:-false};
cleanOutput = x: with nixpkgs.lib; cleanOutput = x: with nixpkgs.lib;
if isDerivation x then x.outPath if isDerivation x then x.outPath
@ -106,12 +168,12 @@ let
else x else x
else x; else x;
in in
cleanOutput (reach nixos.$prefix) cleanOutput value
EOF EOF
} }
evalOpt(){ evalOpt(){
evalAttr "options" "" "$@" evalAttr "option" "" "$@"
} }
evalCfg(){ evalCfg(){
@ -121,8 +183,11 @@ evalCfg(){
findSources(){ findSources(){
local suffix=$1 local suffix=$1
echo "(import <nixos> {}).options${option:+.$option}.$suffix" | evalNix --strict <<EOF
evalNix --strict $header
option.$suffix
EOF
} }
# Given a result from nix-instantiate, recover the list of attributes it # Given a result from nix-instantiate, recover the list of attributes it
@ -152,13 +217,12 @@ nixMap() {
# the output of nixos-option with other tools such as nixos-gui. # the output of nixos-option with other tools such as nixos-gui.
if $xml; then if $xml; then
evalNix --xml --no-location <<EOF evalNix --xml --no-location <<EOF
$header
let let
reach = attrs: attrs${option:+.$option};
nixos = import <nixos> {};
nixpkgs = import <nixpkgs> {};
sources = builtins.map (f: f.source); sources = builtins.map (f: f.source);
opt = reach nixos.options; opt = option;
cfg = reach nixos.config; cfg = config;
in in
with nixpkgs.lib; with nixpkgs.lib;