void CommImpl::finish()
{
+ XBT_DEBUG("CommImpl::finish() in state %s", to_c_str(state_));
while (not simcalls_.empty()) {
smx_simcall_t simcall = simcalls_.front();
simcalls_.pop_front();
if (mbox_)
mbox_->remove(this);
- XBT_DEBUG("CommImpl::finish(): synchro state = %d", static_cast<int>(state_));
-
/* Check out for errors */
if (not simcall->issuer_->get_host()->is_on()) {
} else {
switch (state_) {
case State::DONE:
- XBT_DEBUG("Communication %p complete!", this);
copy_data();
break;
break;
default:
- xbt_die("Unexpected synchro state in CommImpl::finish: %d", static_cast<int>(state_));
+ xbt_die("Internal error in CommImpl::finish(): unexpected synchro state %s", to_c_str(state_));
}
simcall->issuer_->simcall_answer();
}
void ExecImpl::finish()
{
+ XBT_DEBUG("ExecImpl::finish() in state %s", to_c_str(state_));
while (not simcalls_.empty()) {
smx_simcall_t simcall = simcalls_.front();
simcalls_.pop_front();
}
}
switch (state_) {
- case State::DONE:
- /* do nothing, synchro done */
- XBT_DEBUG("ExecImpl::finish(): execution successful");
- break;
-
case State::FAILED:
- XBT_DEBUG("ExecImpl::finish(): host '%s' failed", simcall->issuer_->get_host()->get_cname());
simcall->issuer_->context_->set_wannadie();
if (simcall->issuer_->get_host()->is_on())
simcall->issuer_->exception_ =
break;
case State::CANCELED:
- XBT_DEBUG("ExecImpl::finish(): execution canceled");
simcall->issuer_->exception_ =
std::make_exception_ptr(simgrid::CancelException(XBT_THROW_POINT, "Execution Canceled"));
break;
case State::TIMEOUT:
- XBT_DEBUG("ExecImpl::finish(): execution timeouted");
simcall->issuer_->exception_ = std::make_exception_ptr(simgrid::TimeoutException(XBT_THROW_POINT, "Timeouted"));
break;
default:
- xbt_die("Internal error in ExecImpl::finish(): unexpected synchro state %d", static_cast<int>(state_));
+ xbt_assert(state_ == State::DONE, "Internal error in ExecImpl::finish(): unexpected synchro state %s",
+ to_c_str(state_));
}
simcall->issuer_->waiting_synchro_ = nullptr;
void IoImpl::finish()
{
+ XBT_DEBUG("IoImpl::finish() in state %s", to_c_str(state_));
while (not simcalls_.empty()) {
const s_smx_simcall* simcall = simcalls_.front();
simcalls_.pop_front();
switch (state_) {
- case State::DONE:
- /* do nothing, synchro done */
- break;
case State::FAILED:
simcall->issuer_->context_->set_wannadie();
simcall->issuer_->exception_ =
simcall->issuer_->exception_ = std::make_exception_ptr(CancelException(XBT_THROW_POINT, "I/O Canceled"));
break;
case State::TIMEOUT:
- XBT_DEBUG("IoImpl::finish(): execution timeouted");
simcall->issuer_->exception_ = std::make_exception_ptr(simgrid::TimeoutException(XBT_THROW_POINT, "Timeouted"));
break;
default:
- xbt_die("Internal error in IoImpl::finish(): unexpected synchro state %d", static_cast<int>(state_));
+ xbt_assert(state_ == State::DONE, "Internal error in IoImpl::finish(): unexpected synchro state %s",
+ to_c_str(state_));
}
simcall->issuer_->waiting_synchro_ = nullptr;
void SleepImpl::finish()
{
+ XBT_DEBUG("SleepImpl::finish() in state %s", to_c_str(state_));
while (not simcalls_.empty()) {
const s_smx_simcall* simcall = simcalls_.front();
simcalls_.pop_front();
void RawImpl::finish()
{
+ XBT_DEBUG("RawImpl::finish() in state %s", to_c_str(state_));
xbt_assert(simcalls_.size() == 1, "Unexpected number of simcalls waiting: %zu", simcalls_.size());
smx_simcall_t simcall = simcalls_.front();
simcalls_.pop_front();
if (state_ == State::FAILED) {
- XBT_DEBUG("RawImpl::finish(): host '%s' failed", simcall->issuer_->get_host()->get_cname());
simcall->issuer_->context_->set_wannadie();
simcall->issuer_->exception_ = std::make_exception_ptr(HostFailureException(XBT_THROW_POINT, "Host failed"));
} else {
- xbt_assert(state_ == State::SRC_TIMEOUT, "Internal error in RawImpl::finish() unexpected synchro state %d",
- static_cast<int>(state_));
+ xbt_assert(state_ == State::SRC_TIMEOUT, "Internal error in RawImpl::finish() unexpected synchro state %s",
+ to_c_str(state_));
}
finish_callback_();