aboutsummaryrefslogtreecommitdiff
path: root/src/libstore
diff options
context:
space:
mode:
authoreldritch horrors <pennae@lix.systems>2024-03-04 07:15:08 +0100
committereldritch horrors <pennae@lix.systems>2024-03-04 07:15:08 +0100
commit13f78c557b402422aefc09cc217b001d83f08baa (patch)
tree09cd9c8708df37bbc9bdfddcc26f20d82320e4b3 /src/libstore
parentbc34274aae277bb5b05d3e833fbdc0bd30c7250a (diff)
Merge pull request #9589 from obsidiansystems/floating-content-addressing-derivations-eval-store
Fix building CA derivations with and eval store (cherry picked from commit dfc0cee7024a082d90a4f68296f55a82dfd52126) Change-Id: I28feb5a36d4fe75f0ed3e3e2db6eb56b67d0f371
Diffstat (limited to 'src/libstore')
-rw-r--r--src/libstore/build/derivation-goal.cc51
-rw-r--r--src/libstore/misc.cc9
-rw-r--r--src/libstore/store-api.hh3
3 files changed, 48 insertions, 15 deletions
diff --git a/src/libstore/build/derivation-goal.cc b/src/libstore/build/derivation-goal.cc
index 01e34448b..e616adb71 100644
--- a/src/libstore/build/derivation-goal.cc
+++ b/src/libstore/build/derivation-goal.cc
@@ -196,10 +196,19 @@ void DerivationGoal::loadDerivation()
things being garbage collected while we're busy. */
worker.evalStore.addTempRoot(drvPath);
- assert(worker.evalStore.isValidPath(drvPath));
+ /* Get the derivation. It is probably in the eval store, but it might be inthe main store:
- /* Get the derivation. */
- drv = std::make_unique<Derivation>(worker.evalStore.readDerivation(drvPath));
+ - Resolved derivation are resolved against main store realisations, and so must be stored there.
+
+ - Dynamic derivations are built, and so are found in the main store.
+ */
+ for (auto * drvStore : { &worker.evalStore, &worker.store }) {
+ if (drvStore->isValidPath(drvPath)) {
+ drv = std::make_unique<Derivation>(drvStore->readDerivation(drvPath));
+ break;
+ }
+ }
+ assert(drv);
haveDerivation();
}
@@ -401,11 +410,15 @@ void DerivationGoal::gaveUpOnSubstitution()
}
/* Copy the input sources from the eval store to the build
- store. */
+ store.
+
+ Note that some inputs might not be in the eval store because they
+ are (resolved) derivation outputs in a resolved derivation. */
if (&worker.evalStore != &worker.store) {
RealisedPath::Set inputSrcs;
for (auto & i : drv->inputSrcs)
- inputSrcs.insert(i);
+ if (worker.evalStore.isValidPath(i))
+ inputSrcs.insert(i);
copyClosure(worker.evalStore, worker.store, inputSrcs);
}
@@ -453,7 +466,7 @@ void DerivationGoal::repairClosure()
std::map<StorePath, StorePath> outputsToDrv;
for (auto & i : inputClosure)
if (i.isDerivation()) {
- auto depOutputs = worker.store.queryPartialDerivationOutputMap(i);
+ auto depOutputs = worker.store.queryPartialDerivationOutputMap(i, &worker.evalStore);
for (auto & j : depOutputs)
if (j.second)
outputsToDrv.insert_or_assign(*j.second, i);
@@ -604,7 +617,13 @@ void DerivationGoal::inputsRealised()
return *outPath;
}
else {
- auto outMap = worker.evalStore.queryDerivationOutputMap(depDrvPath);
+ auto outMap = [&]{
+ for (auto * drvStore : { &worker.evalStore, &worker.store })
+ if (drvStore->isValidPath(depDrvPath))
+ return worker.store.queryDerivationOutputMap(depDrvPath, drvStore);
+ assert(false);
+ }();
+
auto outMapPath = outMap.find(outputName);
if (outMapPath == outMap.end()) {
throw Error(
@@ -1085,8 +1104,12 @@ void DerivationGoal::resolvedFinished()
auto newRealisation = realisation;
newRealisation.id = DrvOutput { initialOutput->outputHash, outputName };
newRealisation.signatures.clear();
- if (!drv->type().isFixed())
- newRealisation.dependentRealisations = drvOutputReferences(worker.store, *drv, realisation.outPath);
+ if (!drv->type().isFixed()) {
+ auto & drvStore = worker.evalStore.isValidPath(drvPath)
+ ? worker.evalStore
+ : worker.store;
+ newRealisation.dependentRealisations = drvOutputReferences(worker.store, *drv, realisation.outPath, &drvStore);
+ }
signRealisation(newRealisation);
worker.store.registerDrvOutput(newRealisation);
}
@@ -1362,7 +1385,10 @@ std::map<std::string, std::optional<StorePath>> DerivationGoal::queryPartialDeri
res.insert_or_assign(name, output.path(worker.store, drv->name, name));
return res;
} else {
- return worker.store.queryPartialDerivationOutputMap(drvPath);
+ for (auto * drvStore : { &worker.evalStore, &worker.store })
+ if (drvStore->isValidPath(drvPath))
+ return worker.store.queryPartialDerivationOutputMap(drvPath, drvStore);
+ assert(false);
}
}
@@ -1375,7 +1401,10 @@ OutputPathMap DerivationGoal::queryDerivationOutputMap()
res.insert_or_assign(name, *output.second);
return res;
} else {
- return worker.store.queryDerivationOutputMap(drvPath);
+ for (auto * drvStore : { &worker.evalStore, &worker.store })
+ if (drvStore->isValidPath(drvPath))
+ return worker.store.queryDerivationOutputMap(drvPath, drvStore);
+ assert(false);
}
}
diff --git a/src/libstore/misc.cc b/src/libstore/misc.cc
index 1035691c7..c8646083b 100644
--- a/src/libstore/misc.cc
+++ b/src/libstore/misc.cc
@@ -330,8 +330,11 @@ std::map<DrvOutput, StorePath> drvOutputReferences(
std::map<DrvOutput, StorePath> drvOutputReferences(
Store & store,
const Derivation & drv,
- const StorePath & outputPath)
+ const StorePath & outputPath,
+ Store * evalStore_)
{
+ auto & evalStore = evalStore_ ? *evalStore_ : store;
+
std::set<Realisation> inputRealisations;
std::function<void(const StorePath &, const DerivedPathMap<StringSet>::ChildNode &)> accumRealisations;
@@ -339,7 +342,7 @@ std::map<DrvOutput, StorePath> drvOutputReferences(
accumRealisations = [&](const StorePath & inputDrv, const DerivedPathMap<StringSet>::ChildNode & inputNode) {
if (!inputNode.value.empty()) {
auto outputHashes =
- staticOutputHashes(store, store.readDerivation(inputDrv));
+ staticOutputHashes(evalStore, evalStore.readDerivation(inputDrv));
for (const auto & outputName : inputNode.value) {
auto outputHash = get(outputHashes, outputName);
if (!outputHash)
@@ -361,7 +364,7 @@ std::map<DrvOutput, StorePath> drvOutputReferences(
SingleDerivedPath next = SingleDerivedPath::Built { d, outputName };
accumRealisations(
// TODO deep resolutions for dynamic derivations, issue #8947, would go here.
- resolveDerivedPath(store, next),
+ resolveDerivedPath(store, next, evalStore_),
childNode);
}
}
diff --git a/src/libstore/store-api.hh b/src/libstore/store-api.hh
index 87fb4c04e..d3d7a315e 100644
--- a/src/libstore/store-api.hh
+++ b/src/libstore/store-api.hh
@@ -1053,6 +1053,7 @@ const ContentAddress * getDerivationCA(const BasicDerivation & drv);
std::map<DrvOutput, StorePath> drvOutputReferences(
Store & store,
const Derivation & drv,
- const StorePath & outputPath);
+ const StorePath & outputPath,
+ Store * evalStore = nullptr);
}