Check non-runnable steps for unsupported system type
This commit is contained in:
parent
5019fceb20
commit
c00bf7cd1a
1 changed files with 9 additions and 8 deletions
|
@ -224,7 +224,7 @@ public:
|
||||||
void removeCancelledBuilds(Connection & conn);
|
void removeCancelledBuilds(Connection & conn);
|
||||||
|
|
||||||
Step::ptr createStep(std::shared_ptr<StoreAPI> store, const Path & drvPath,
|
Step::ptr createStep(std::shared_ptr<StoreAPI> store, const Path & drvPath,
|
||||||
std::set<Step::ptr> & newRunnable);
|
std::set<Step::ptr> & newSteps, std::set<Step::ptr> & newRunnable);
|
||||||
|
|
||||||
void destroyStep(Step::ptr step, bool proceed);
|
void destroyStep(Step::ptr step, bool proceed);
|
||||||
|
|
||||||
|
@ -473,8 +473,8 @@ void State::getQueuedBuilds(Connection & conn, std::shared_ptr<StoreAPI> store,
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::set<Step::ptr> newRunnable;
|
std::set<Step::ptr> newSteps, newRunnable;
|
||||||
Step::ptr step = createStep(store, build->drvPath, newRunnable);
|
Step::ptr step = createStep(store, build->drvPath, newSteps, newRunnable);
|
||||||
|
|
||||||
/* If we didn't get a step, it means the step's outputs are
|
/* If we didn't get a step, it means the step's outputs are
|
||||||
all valid. So we mark this as a finished, cached build. */
|
all valid. So we mark this as a finished, cached build. */
|
||||||
|
@ -495,7 +495,7 @@ void State::getQueuedBuilds(Connection & conn, std::shared_ptr<StoreAPI> store,
|
||||||
/* If any step has an unsupported system type, then fail the
|
/* If any step has an unsupported system type, then fail the
|
||||||
build. */
|
build. */
|
||||||
bool allSupported = true;
|
bool allSupported = true;
|
||||||
for (auto & r : newRunnable) {
|
for (auto & r : newSteps) {
|
||||||
bool supported = false;
|
bool supported = false;
|
||||||
{
|
{
|
||||||
auto machines_(machines.lock()); // FIXME: use shared_mutex
|
auto machines_(machines.lock()); // FIXME: use shared_mutex
|
||||||
|
@ -531,8 +531,8 @@ void State::getQueuedBuilds(Connection & conn, std::shared_ptr<StoreAPI> store,
|
||||||
build->toplevel = step;
|
build->toplevel = step;
|
||||||
}
|
}
|
||||||
|
|
||||||
printMsg(lvlInfo, format("added build %1% (top-level step %2%, %3% new runnable steps)")
|
printMsg(lvlInfo, format("added build %1% (top-level step %2%, %3% new steps, %4% new runnable steps)")
|
||||||
% build->id % step->drvPath % newRunnable.size());
|
% build->id % step->drvPath % newSteps.size() % newRunnable.size());
|
||||||
|
|
||||||
/* Prior to this, the build is not visible to
|
/* Prior to this, the build is not visible to
|
||||||
getDependentBuilds(). Now it is, so the build can be
|
getDependentBuilds(). Now it is, so the build can be
|
||||||
|
@ -572,7 +572,7 @@ void State::removeCancelledBuilds(Connection & conn)
|
||||||
|
|
||||||
|
|
||||||
Step::ptr State::createStep(std::shared_ptr<StoreAPI> store, const Path & drvPath,
|
Step::ptr State::createStep(std::shared_ptr<StoreAPI> store, const Path & drvPath,
|
||||||
std::set<Step::ptr> & newRunnable)
|
std::set<Step::ptr> & newSteps, std::set<Step::ptr> & newRunnable)
|
||||||
{
|
{
|
||||||
/* Check if the requested step already exists. */
|
/* Check if the requested step already exists. */
|
||||||
{
|
{
|
||||||
|
@ -592,6 +592,7 @@ Step::ptr State::createStep(std::shared_ptr<StoreAPI> store, const Path & drvPat
|
||||||
auto step = std::make_shared<Step>();
|
auto step = std::make_shared<Step>();
|
||||||
step->drvPath = drvPath;
|
step->drvPath = drvPath;
|
||||||
step->drv = readDerivation(drvPath);
|
step->drv = readDerivation(drvPath);
|
||||||
|
newSteps.insert(step);
|
||||||
|
|
||||||
/* Are all outputs valid? */
|
/* Are all outputs valid? */
|
||||||
bool valid = true;
|
bool valid = true;
|
||||||
|
@ -611,7 +612,7 @@ Step::ptr State::createStep(std::shared_ptr<StoreAPI> store, const Path & drvPat
|
||||||
/* Create steps for the dependencies. */
|
/* Create steps for the dependencies. */
|
||||||
bool hasDeps = false;
|
bool hasDeps = false;
|
||||||
for (auto & i : step->drv.inputDrvs) {
|
for (auto & i : step->drv.inputDrvs) {
|
||||||
Step::ptr dep = createStep(store, i.first, newRunnable);
|
Step::ptr dep = createStep(store, i.first, newSteps, newRunnable);
|
||||||
if (dep) {
|
if (dep) {
|
||||||
hasDeps = true;
|
hasDeps = true;
|
||||||
auto step_(step->state.lock());
|
auto step_(step->state.lock());
|
||||||
|
|
Loading…
Reference in a new issue