mirror of
https://github.com/NixOS/nix.git
synced 2025-11-08 19:46:02 +01:00
fix(libstore/build/derivation-goal): don't assert on partially valid outputs
Fixes: #14130
(cherry picked from commit 9eecee3d4e)
This commit is contained in:
parent
f434a3e3c6
commit
f566957dc4
1 changed files with 13 additions and 1 deletions
|
|
@ -182,7 +182,19 @@ Goal::Co DerivationGoal::haveDerivation()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
assert(success.builtOutputs.count(wantedOutput) > 0);
|
/* If the wanted output is not in builtOutputs (e.g., because it
|
||||||
|
was already valid and therefore not re-registered), we need to
|
||||||
|
add it ourselves to ensure we return the correct information. */
|
||||||
|
if (success.builtOutputs.count(wantedOutput) == 0) {
|
||||||
|
debug(
|
||||||
|
"BUG! wanted output '%s' not in builtOutputs, working around by adding it manually", wantedOutput);
|
||||||
|
auto realisation = assertPathValidity();
|
||||||
|
realisation.id = DrvOutput{
|
||||||
|
.drvHash = outputHash,
|
||||||
|
.outputName = wantedOutput,
|
||||||
|
};
|
||||||
|
success.builtOutputs.emplace(wantedOutput, std::move(realisation));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue