+ bool is_ready() const
+ {
+ if (not valid())
+ throw std::future_error(std::future_errc::no_state);
+ return future_.is_ready();
+ }
+ void wait()
+ {
+ // The future is ready! We don't have to wait:
+ if (this->is_ready())
+ return;
+ // The future is not ready. We have to delegate to the SimGrid kernel:
+ std::exception_ptr exception;
+ smx_actor_t self = SIMIX_process_self();
+ simcall_run_blocking([this, &exception, self]{
+ try {
+ // When the kernel future is ready...
+ this->future_.then_([this, self](std::shared_ptr<simgrid::kernel::FutureState<T>>&& value) {
+ // ...store it the simix kernel and wake up.
+ this->future_ = std::move(simgrid::kernel::Future<T>(value));
+ simgrid::simix::unblock(self);
+ });
+ }
+ catch (...) {
+ exception = std::current_exception();
+ simgrid::simix::unblock(self);
+ }
+ });
+ }