forked from lix-project/lix
Detect and reject mutually-referential outputs
There is probably a more efficient way to do this.
This commit is contained in:
parent
b19a0f63db
commit
f3c88f297d
1 changed files with 9 additions and 0 deletions
|
@ -1986,6 +1986,15 @@ void DerivationGoal::computeClosure()
|
||||||
info.deriver = drvPath;
|
info.deriver = drvPath;
|
||||||
infos.push_back(info);
|
infos.push_back(info);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Mutually recursive outputs are not allowed */
|
||||||
|
foreach (ValidPathInfos::iterator, i, infos)
|
||||||
|
foreach (ValidPathInfos::iterator, j, infos)
|
||||||
|
if ((i->path != j->path) &&
|
||||||
|
(i->references.find(j->path) != i->references.end()) &&
|
||||||
|
(j->references.find(i->path) != j->references.end()))
|
||||||
|
throw BuildError(format("Mutually referential outputs are not allowed: outputs `%1%' and `%2%' refer to each other") % i->path % j->path);
|
||||||
|
|
||||||
worker.store.registerValidPaths(infos);
|
worker.store.registerValidPaths(infos);
|
||||||
|
|
||||||
/* It is now safe to delete the lock files, since all future
|
/* It is now safe to delete the lock files, since all future
|
||||||
|
|
Loading…
Reference in a new issue