diff --git a/src/hydra-queue-runner/builder.cc b/src/hydra-queue-runner/builder.cc index 9f01425d..b0e96e95 100644 --- a/src/hydra-queue-runner/builder.cc +++ b/src/hydra-queue-runner/builder.cc @@ -13,13 +13,14 @@ void State::builder(MachineReservation::ptr reservation) nrStepsStarted++; - reservation->threadId = pthread_self(); - - activeSteps_.lock()->insert(reservation); + auto activeStep = std::make_shared(); + activeStep->step = reservation->step; + activeStep->threadId = pthread_self(); + activeSteps_.lock()->insert(activeStep); Finally removeActiveStep([&]() { - reservation->threadId = -1; - activeSteps_.lock()->erase(reservation); + activeStep->threadId = -1; + activeSteps_.lock()->erase(activeStep); }); auto step = reservation->step; diff --git a/src/hydra-queue-runner/state.hh b/src/hydra-queue-runner/state.hh index 31898d01..7de2af86 100644 --- a/src/hydra-queue-runner/state.hh +++ b/src/hydra-queue-runner/state.hh @@ -370,13 +370,17 @@ private: State & state; Step::ptr step; Machine::ptr machine; - pthread_t threadId = 0; - bool cancelled = false; MachineReservation(State & state, Step::ptr step, Machine::ptr machine); ~MachineReservation(); }; - nix::Sync>> activeSteps_; + struct ActiveStep + { + Step::ptr step; + pthread_t threadId; + }; + + nix::Sync>> activeSteps_; std::atomic lastDispatcherCheck{0};