mirror of
https://github.com/matrix-org/matrix-rust-sdk.git
synced 2026-04-28 11:09:51 -04:00
common: Add executor::JoinHandle
… and simplify wasm spawn implementation. This reduces the differences on wasm vs. non-wasm. Of course it's still possible to rely on details of the different error types, but at least both implement a few common traits: `Debug`, `Display`, `Error`.
This commit is contained in:
committed by
Jonas Platte
parent
8aa12c929a
commit
adb9e60fbe
@@ -15,6 +15,8 @@
|
||||
//! Abstraction over an executor so we can spawn tasks under WASM the same way
|
||||
//! we do usually.
|
||||
|
||||
#[cfg(target_arch = "wasm32")]
|
||||
pub use std::convert::Infallible as JoinError;
|
||||
#[cfg(target_arch = "wasm32")]
|
||||
use std::{
|
||||
future::Future,
|
||||
@@ -25,15 +27,14 @@ use std::{
|
||||
#[cfg(target_arch = "wasm32")]
|
||||
use futures_util::{future::RemoteHandle, FutureExt};
|
||||
#[cfg(not(target_arch = "wasm32"))]
|
||||
pub use tokio::task::{spawn, JoinHandle};
|
||||
pub use tokio::task::{spawn, JoinError, JoinHandle};
|
||||
|
||||
#[cfg(target_arch = "wasm32")]
|
||||
pub fn spawn<F, T>(future: F) -> JoinHandle<T>
|
||||
where
|
||||
F: Future<Output = T> + 'static,
|
||||
{
|
||||
let fut = future.unit_error();
|
||||
let (fut, handle) = fut.remote_handle();
|
||||
let (fut, handle) = future.remote_handle();
|
||||
wasm_bindgen_futures::spawn_local(fut);
|
||||
|
||||
JoinHandle { handle }
|
||||
@@ -42,14 +43,14 @@ where
|
||||
#[cfg(target_arch = "wasm32")]
|
||||
#[derive(Debug)]
|
||||
pub struct JoinHandle<T> {
|
||||
handle: RemoteHandle<Result<T, ()>>,
|
||||
handle: RemoteHandle<T>,
|
||||
}
|
||||
|
||||
#[cfg(target_arch = "wasm32")]
|
||||
impl<T: 'static> Future for JoinHandle<T> {
|
||||
type Output = Result<T, ()>;
|
||||
type Output = Result<T, JoinError>;
|
||||
|
||||
fn poll(mut self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Self::Output> {
|
||||
Pin::new(&mut self.handle).poll(cx)
|
||||
Pin::new(&mut self.handle).poll(cx).map(Ok)
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user