set_start_time(model_action_->get_start_time());
}
+ /* Allow execs to fail if any their host fail (or any of their host for parallel execs) */
+ cb_id_ = s4u::Host::on_state_change.connect([this](s4u::Host const& h) {
+ if (not h.is_on() && get_state() == kernel::activity::State::RUNNING &&
+ std::find(get_hosts().begin(), get_hosts().end(), &h) != get_hosts().end()) {
+ set_state(kernel::activity::State::FAILED);
+ finish();
+ }
+ });
+
XBT_DEBUG("Create execute synchro %p: %s", this, get_cname());
return this;
}
ExecImpl& set_sharing_penalty(double sharing_penalty);
ExecImpl& update_sharing_penalty(double sharing_penalty);
- void set_cb_id(unsigned int cb_id) { cb_id_ = cb_id; }
-
ExecImpl& set_flops_amount(double flop_amount);
ExecImpl& set_host(s4u::Host* host);
ExecPtr Exec::init()
{
auto pimpl = kernel::activity::ExecImplPtr(new kernel::activity::ExecImpl());
- /* Allow parallel execs to fail if any of their hosts fail */
- unsigned int cb_id = Host::on_state_change.connect([pimpl](s4u::Host const& h) {
- if (not h.is_on() && pimpl->get_state() == kernel::activity::State::RUNNING &&
- std::find(pimpl->get_hosts().begin(), pimpl->get_hosts().end(), &h) != pimpl->get_hosts().end()) {
- pimpl->set_state(kernel::activity::State::FAILED);
- pimpl->finish();
- }
- });
- pimpl->set_cb_id(cb_id);
return ExecPtr(static_cast<Exec*>(pimpl->get_iface()));
}