forked from lix-project/lix
* Export the references graph to the build hook.
This commit is contained in:
parent
3f236f01ae
commit
0df9f08078
1 changed files with 32 additions and 16 deletions
|
@ -806,36 +806,52 @@ DerivationGoal::HookReply DerivationGoal::tryBuildHook()
|
||||||
Path outputListFN = tmpDir + "/outputs";
|
Path outputListFN = tmpDir + "/outputs";
|
||||||
Path referencesFN = tmpDir + "/references";
|
Path referencesFN = tmpDir + "/references";
|
||||||
|
|
||||||
|
/* The `inputs' file lists all inputs that have to be copied
|
||||||
|
to the remote system. This unfortunately has to contain
|
||||||
|
the entire derivation closure to ensure that the validity
|
||||||
|
invariant holds on the remote system. (I.e., it's
|
||||||
|
unfortunate that we have to list it since the remote system
|
||||||
|
*probably* already has it.) */
|
||||||
|
PathSet allInputs;
|
||||||
|
allInputs.insert(inputPaths.begin(), inputPaths.end());
|
||||||
|
computeFSClosure(drvPath, allInputs);
|
||||||
|
|
||||||
string s;
|
string s;
|
||||||
for (PathSet::iterator i = inputPaths.begin();
|
for (PathSet::iterator i = allInputs.begin();
|
||||||
i != inputPaths.end(); ++i)
|
i != allInputs.end(); ++i)
|
||||||
s += *i + "\n";
|
s += *i + "\n";
|
||||||
for (DerivationInputs::iterator i = drv.inputDrvs.begin();
|
|
||||||
i != drv.inputDrvs.end(); ++i)
|
|
||||||
s += i->first + "\n";
|
|
||||||
writeStringToFile(inputListFN, s);
|
writeStringToFile(inputListFN, s);
|
||||||
|
|
||||||
|
/* The `outputs' file lists all outputs that have to be copied
|
||||||
|
from the remote system. */
|
||||||
s = "";
|
s = "";
|
||||||
for (DerivationOutputs::iterator i = drv.outputs.begin();
|
for (DerivationOutputs::iterator i = drv.outputs.begin();
|
||||||
i != drv.outputs.end(); ++i)
|
i != drv.outputs.end(); ++i)
|
||||||
s += i->second.path + "\n";
|
s += i->second.path + "\n";
|
||||||
writeStringToFile(outputListFN, s);
|
writeStringToFile(outputListFN, s);
|
||||||
|
|
||||||
|
/* The `references' file has exactly the format accepted by
|
||||||
|
`nix-store --register-validity'. */
|
||||||
s = "";
|
s = "";
|
||||||
for (PathSet::iterator i = inputPaths.begin();
|
for (PathSet::iterator i = allInputs.begin();
|
||||||
i != inputPaths.end(); ++i)
|
i != allInputs.end(); ++i)
|
||||||
{
|
{
|
||||||
s += *i;
|
s += *i + "\n";
|
||||||
|
|
||||||
|
Path deriver = queryDeriver(noTxn, *i);
|
||||||
|
s += deriver + "\n";
|
||||||
|
|
||||||
PathSet references;
|
PathSet references;
|
||||||
queryReferences(noTxn, *i, references);
|
queryReferences(noTxn, *i, references);
|
||||||
|
|
||||||
|
s += (format("%1%\n") % references.size()).str();
|
||||||
|
|
||||||
for (PathSet::iterator j = references.begin();
|
for (PathSet::iterator j = references.begin();
|
||||||
j != references.end(); ++j)
|
j != references.end(); ++j)
|
||||||
{
|
s += *j + "\n";
|
||||||
s += " ";
|
|
||||||
s += *j;
|
|
||||||
}
|
|
||||||
s += "\n";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
writeStringToFile(referencesFN, s);
|
writeStringToFile(referencesFN, s);
|
||||||
|
|
||||||
/* Tell the hook to proceed. */
|
/* Tell the hook to proceed. */
|
||||||
|
|
Loading…
Reference in a new issue