2006-02-08 13:21:16 +00:00
|
|
|
#include "get-drvs.hh"
|
|
|
|
#include "nixexpr-ast.hh"
|
|
|
|
|
|
|
|
|
|
|
|
bool getDerivation(EvalState & state, Expr e, DrvInfo & drv)
|
|
|
|
{
|
|
|
|
ATermList es;
|
|
|
|
e = evalExpr(state, e);
|
|
|
|
if (!matchAttrs(e, es)) return false;
|
|
|
|
|
|
|
|
ATermMap attrs;
|
|
|
|
queryAllAttrs(e, attrs, false);
|
|
|
|
|
|
|
|
Expr a = attrs.get("type");
|
|
|
|
if (!a || evalString(state, a) != "derivation") return false;
|
|
|
|
|
|
|
|
a = attrs.get("name");
|
|
|
|
if (!a) throw badTerm("derivation name missing", e);
|
|
|
|
drv.name = evalString(state, a);
|
|
|
|
|
|
|
|
a = attrs.get("system");
|
|
|
|
if (!a)
|
|
|
|
drv.system = "unknown";
|
|
|
|
else
|
|
|
|
drv.system = evalString(state, a);
|
|
|
|
|
|
|
|
drv.attrs = attrs;
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void getDerivations(EvalState & state, Expr e, DrvInfos & drvs)
|
|
|
|
{
|
|
|
|
ATermList es;
|
|
|
|
DrvInfo drv;
|
|
|
|
|
|
|
|
e = evalExpr(state, e);
|
|
|
|
|
2006-02-08 15:22:30 +00:00
|
|
|
if (getDerivation(state, e, drv)) {
|
2006-02-08 13:21:16 +00:00
|
|
|
drvs.push_back(drv);
|
2006-02-08 15:22:30 +00:00
|
|
|
return;
|
|
|
|
}
|
2006-02-08 13:21:16 +00:00
|
|
|
|
2006-02-08 15:22:30 +00:00
|
|
|
if (matchAttrs(e, es)) {
|
2006-02-08 13:21:16 +00:00
|
|
|
ATermMap drvMap;
|
|
|
|
queryAllAttrs(e, drvMap);
|
|
|
|
for (ATermIterator i(drvMap.keys()); i; ++i) {
|
|
|
|
debug(format("evaluating attribute `%1%'") % aterm2String(*i));
|
|
|
|
if (getDerivation(state, drvMap.get(*i), drv))
|
|
|
|
drvs.push_back(drv);
|
|
|
|
else
|
|
|
|
;
|
|
|
|
// parseDerivations(state, drvMap.get(*i), drvs);
|
|
|
|
}
|
2006-02-08 15:22:30 +00:00
|
|
|
return;
|
2006-02-08 13:21:16 +00:00
|
|
|
}
|
|
|
|
|
2006-02-08 15:22:30 +00:00
|
|
|
if (matchList(e, es)) {
|
2006-02-08 13:21:16 +00:00
|
|
|
for (ATermIterator i(es); i; ++i) {
|
|
|
|
debug(format("evaluating list element"));
|
|
|
|
if (getDerivation(state, *i, drv))
|
|
|
|
drvs.push_back(drv);
|
|
|
|
else
|
|
|
|
getDerivations(state, *i, drvs);
|
|
|
|
}
|
2006-02-08 15:22:30 +00:00
|
|
|
return;
|
2006-02-08 13:21:16 +00:00
|
|
|
}
|
|
|
|
|
2006-02-08 15:22:30 +00:00
|
|
|
ATermList formals;
|
|
|
|
ATerm body, pos;
|
|
|
|
if (matchFunction(e, formals, body, pos)) {
|
|
|
|
for (ATermIterator i(formals); i; ++i) {
|
|
|
|
Expr name, def;
|
|
|
|
if (matchNoDefFormal(*i, name))
|
|
|
|
throw Error(format("expression evaluates to a function with no-default arguments (`%1%')")
|
|
|
|
% aterm2String(name));
|
|
|
|
else if (!matchDefFormal(*i, name, def))
|
|
|
|
abort(); /* can't happen */
|
|
|
|
}
|
|
|
|
getDerivations(state, makeCall(e, makeAttrs(ATermMap())), drvs);
|
|
|
|
return;
|
|
|
|
}
|
2006-02-08 13:21:16 +00:00
|
|
|
|
2006-02-08 15:22:30 +00:00
|
|
|
throw Error("expression does not evaluate to a derivation (or a set or list of those)");
|
|
|
|
}
|