- switch (state_) {
- case State::DONE:
- /* do nothing, synchro done */
- break;
- case State::FAILED:
- simcall->issuer_->context_->set_wannadie();
- simcall->issuer_->exception_ =
- std::make_exception_ptr(StorageFailureException(XBT_THROW_POINT, "Storage failed"));
- break;
- case State::CANCELED:
- 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_));
- }
+
+ /* If a waitany simcall is waiting for this synchro to finish, then remove it from the other synchros in the waitany
+ * list. Afterwards, get the position of the actual synchro in the waitany list and return it as the result of the
+ * simcall */
+
+ if (simcall->call_ == actor::Simcall::Type::NONE) // FIXME: maybe a better way to handle this case
+ continue; // if process handling comm is killed
+
+ handle_activity_waitany(simcall);
+
+ set_exception(simcall->issuer_);