mirror of
https://github.com/privatevoid-net/nix-super.git
synced 2024-11-15 02:36:16 +02:00
commit
12e31ab77d
1 changed files with 77 additions and 52 deletions
|
@ -178,6 +178,78 @@ static void mkOutputString(
|
||||||
o.second.path(*state.store, Derivation::nameFromPath(drvPath), o.first));
|
o.second.path(*state.store, Derivation::nameFromPath(drvPath), o.first));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* `import` will parse a derivation when it imports a `.drv` file from the store.
|
||||||
|
*
|
||||||
|
* @param state The evaluation state.
|
||||||
|
* @param pos The position of the `import` call.
|
||||||
|
* @param path The path to the `.drv` to import.
|
||||||
|
* @param storePath The path to the `.drv` to import.
|
||||||
|
* @param v Return value
|
||||||
|
*/
|
||||||
|
void derivationToValue(EvalState & state, const PosIdx pos, const SourcePath & path, const StorePath & storePath, Value & v) {
|
||||||
|
auto path2 = path.path.abs();
|
||||||
|
Derivation drv = state.store->readDerivation(storePath);
|
||||||
|
auto attrs = state.buildBindings(3 + drv.outputs.size());
|
||||||
|
attrs.alloc(state.sDrvPath).mkString(path2, {
|
||||||
|
NixStringContextElem::DrvDeep { .drvPath = storePath },
|
||||||
|
});
|
||||||
|
attrs.alloc(state.sName).mkString(drv.env["name"]);
|
||||||
|
|
||||||
|
auto list = state.buildList(drv.outputs.size());
|
||||||
|
for (const auto & [i, o] : enumerate(drv.outputs)) {
|
||||||
|
mkOutputString(state, attrs, storePath, o);
|
||||||
|
(list[i] = state.allocValue())->mkString(o.first);
|
||||||
|
}
|
||||||
|
attrs.alloc(state.sOutputs).mkList(list);
|
||||||
|
|
||||||
|
auto w = state.allocValue();
|
||||||
|
w->mkAttrs(attrs);
|
||||||
|
|
||||||
|
if (!state.vImportedDrvToDerivation) {
|
||||||
|
state.vImportedDrvToDerivation = allocRootValue(state.allocValue());
|
||||||
|
state.eval(state.parseExprFromString(
|
||||||
|
#include "imported-drv-to-derivation.nix.gen.hh"
|
||||||
|
, state.rootPath(CanonPath::root)), **state.vImportedDrvToDerivation);
|
||||||
|
}
|
||||||
|
|
||||||
|
state.forceFunction(**state.vImportedDrvToDerivation, pos, "while evaluating imported-drv-to-derivation.nix.gen.hh");
|
||||||
|
v.mkApp(*state.vImportedDrvToDerivation, w);
|
||||||
|
state.forceAttrs(v, pos, "while calling imported-drv-to-derivation.nix.gen.hh");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Import a Nix file with an alternate base scope, as `builtins.scopedImport` does.
|
||||||
|
*
|
||||||
|
* @param state The evaluation state.
|
||||||
|
* @param pos The position of the import call.
|
||||||
|
* @param path The path to the file to import.
|
||||||
|
* @param vScope The base scope to use for the import.
|
||||||
|
* @param v Return value
|
||||||
|
*/
|
||||||
|
static void scopedImport(EvalState & state, const PosIdx pos, SourcePath & path, Value * vScope, Value & v) {
|
||||||
|
state.forceAttrs(*vScope, pos, "while evaluating the first argument passed to builtins.scopedImport");
|
||||||
|
|
||||||
|
Env * env = &state.allocEnv(vScope->attrs()->size());
|
||||||
|
env->up = &state.baseEnv;
|
||||||
|
|
||||||
|
auto staticEnv = std::make_shared<StaticEnv>(nullptr, state.staticBaseEnv.get(), vScope->attrs()->size());
|
||||||
|
|
||||||
|
unsigned int displ = 0;
|
||||||
|
for (auto & attr : *vScope->attrs()) {
|
||||||
|
staticEnv->vars.emplace_back(attr.name, displ);
|
||||||
|
env->values[displ++] = attr.value;
|
||||||
|
}
|
||||||
|
|
||||||
|
// No need to call staticEnv.sort(), because
|
||||||
|
// args[0]->attrs is already sorted.
|
||||||
|
|
||||||
|
printTalkative("evaluating file '%1%'", path);
|
||||||
|
Expr * e = state.parseExprFromFile(resolveExprPath(path), staticEnv);
|
||||||
|
|
||||||
|
e->eval(state, *env, v);
|
||||||
|
}
|
||||||
|
|
||||||
/* Load and evaluate an expression from path specified by the
|
/* Load and evaluate an expression from path specified by the
|
||||||
argument. */
|
argument. */
|
||||||
static void import(EvalState & state, const PosIdx pos, Value & vPath, Value * vScope, Value & v)
|
static void import(EvalState & state, const PosIdx pos, Value & vPath, Value * vScope, Value & v)
|
||||||
|
@ -196,60 +268,13 @@ static void import(EvalState & state, const PosIdx pos, Value & vPath, Value * v
|
||||||
};
|
};
|
||||||
|
|
||||||
if (auto storePath = isValidDerivationInStore()) {
|
if (auto storePath = isValidDerivationInStore()) {
|
||||||
Derivation drv = state.store->readDerivation(*storePath);
|
derivationToValue(state, pos, path, *storePath, v);
|
||||||
auto attrs = state.buildBindings(3 + drv.outputs.size());
|
}
|
||||||
attrs.alloc(state.sDrvPath).mkString(path2, {
|
else if (vScope) {
|
||||||
NixStringContextElem::DrvDeep { .drvPath = *storePath },
|
scopedImport(state, pos, path, vScope, v);
|
||||||
});
|
|
||||||
attrs.alloc(state.sName).mkString(drv.env["name"]);
|
|
||||||
|
|
||||||
auto list = state.buildList(drv.outputs.size());
|
|
||||||
for (const auto & [i, o] : enumerate(drv.outputs)) {
|
|
||||||
mkOutputString(state, attrs, *storePath, o);
|
|
||||||
(list[i] = state.allocValue())->mkString(o.first);
|
|
||||||
}
|
|
||||||
attrs.alloc(state.sOutputs).mkList(list);
|
|
||||||
|
|
||||||
auto w = state.allocValue();
|
|
||||||
w->mkAttrs(attrs);
|
|
||||||
|
|
||||||
if (!state.vImportedDrvToDerivation) {
|
|
||||||
state.vImportedDrvToDerivation = allocRootValue(state.allocValue());
|
|
||||||
state.eval(state.parseExprFromString(
|
|
||||||
#include "imported-drv-to-derivation.nix.gen.hh"
|
|
||||||
, state.rootPath(CanonPath::root)), **state.vImportedDrvToDerivation);
|
|
||||||
}
|
|
||||||
|
|
||||||
state.forceFunction(**state.vImportedDrvToDerivation, pos, "while evaluating imported-drv-to-derivation.nix.gen.hh");
|
|
||||||
v.mkApp(*state.vImportedDrvToDerivation, w);
|
|
||||||
state.forceAttrs(v, pos, "while calling imported-drv-to-derivation.nix.gen.hh");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
else {
|
else {
|
||||||
if (!vScope)
|
state.evalFile(path, v);
|
||||||
state.evalFile(path, v);
|
|
||||||
else {
|
|
||||||
state.forceAttrs(*vScope, pos, "while evaluating the first argument passed to builtins.scopedImport");
|
|
||||||
|
|
||||||
Env * env = &state.allocEnv(vScope->attrs()->size());
|
|
||||||
env->up = &state.baseEnv;
|
|
||||||
|
|
||||||
auto staticEnv = std::make_shared<StaticEnv>(nullptr, state.staticBaseEnv.get(), vScope->attrs()->size());
|
|
||||||
|
|
||||||
unsigned int displ = 0;
|
|
||||||
for (auto & attr : *vScope->attrs()) {
|
|
||||||
staticEnv->vars.emplace_back(attr.name, displ);
|
|
||||||
env->values[displ++] = attr.value;
|
|
||||||
}
|
|
||||||
|
|
||||||
// No need to call staticEnv.sort(), because
|
|
||||||
// args[0]->attrs is already sorted.
|
|
||||||
|
|
||||||
printTalkative("evaluating file '%1%'", path);
|
|
||||||
Expr * e = state.parseExprFromFile(resolveExprPath(path), staticEnv);
|
|
||||||
|
|
||||||
e->eval(state, *env, v);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue