diff options
author | Eelco Dolstra <e.dolstra@tudelft.nl> | 2006-08-23 16:20:14 +0000 |
---|---|---|
committer | Eelco Dolstra <e.dolstra@tudelft.nl> | 2006-08-23 16:20:14 +0000 |
commit | 9638f3f3930bffab8a547ec59502ae72e203d9ff (patch) | |
tree | 1eff6f713e9ff4e90e04e098b158f110b7adc696 /src/nix-instantiate | |
parent | b19cebc513c2d513ee1f91b5ce12f30c5dd095f2 (diff) | |
download | guix-9638f3f3930bffab8a547ec59502ae72e203d9ff.tar.gz |
* Pass the autoArgs to findAlongAttrPath so that "nix-instantiate
foo.nix -A attr --arg name value" will work if (name, value) is needed in the evaluation leading up to "attr".
Diffstat (limited to 'src/nix-instantiate')
-rw-r--r-- | src/nix-instantiate/main.cc | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/src/nix-instantiate/main.cc b/src/nix-instantiate/main.cc index 0ea639dd91..29a28c3d83 100644 --- a/src/nix-instantiate/main.cc +++ b/src/nix-instantiate/main.cc @@ -178,9 +178,10 @@ Expr strictEval(EvalState & state, Expr e) } -Expr doEval(EvalState & state, string attrPath, bool parseOnly, bool strict, Expr e) +Expr doEval(EvalState & state, string attrPath, bool parseOnly, bool strict, + const ATermMap & autoArgs, Expr e) { - e = findAlongAttrPath(state, attrPath, e); + e = findAlongAttrPath(state, attrPath, autoArgs, e); if (!parseOnly) if (strict) e = strictEval(state, e); @@ -229,6 +230,7 @@ void run(Strings args) if (i == args.end()) throw UsageError("`--arg' requires two arguments"); Expr value = parseExprFromString(state, *i++, absPath(".")); + printMsg(lvlError, format("X %1% Y %2%") % name % value); autoArgs.set(toATerm(name), value); } else if (arg == "--add-root") { @@ -252,7 +254,7 @@ void run(Strings args) if (readStdin) { Expr e = parseStdin(state); - e = doEval(state, attrPath, parseOnly, strict, e); + e = doEval(state, attrPath, parseOnly, strict, autoArgs, e); printResult(state, e, evalOnly, xmlOutput, autoArgs); } @@ -261,7 +263,7 @@ void run(Strings args) { Path path = absPath(*i); Expr e = parseExprFromFile(state, path); - e = doEval(state, attrPath, parseOnly, strict, e); + e = doEval(state, attrPath, parseOnly, strict, autoArgs, e); printResult(state, e, evalOnly, xmlOutput, autoArgs); } |