When built with tokio, provide a SingleThreadExecutor

An application can (optionally) use this to spawn a single tokio thread
instead of one per processor thread.
This commit is contained in:
Ian Douglas Scott 2023-01-18 15:09:55 -08:00 committed by Jeremy Soller
parent abf8fc96c2
commit db2e6c236d
3 changed files with 35 additions and 1 deletions

View file

@ -0,0 +1,28 @@
use std::{future::Future, thread};
#[cfg(feature = "tokio")]
pub struct SingleThreadExecutor(tokio::runtime::Runtime);
#[cfg(feature = "tokio")]
impl iced_native::Executor for SingleThreadExecutor {
fn new() -> Result<Self, iced::futures::io::Error> {
// Current thread executor requires calling `block_on` to actually run
// futures. Main thread is busy with things other than running futures,
// so spawn a single worker thread.
Ok(Self(
tokio::runtime::Builder::new_multi_thread()
.worker_threads(1)
.enable_all()
.build()?,
))
}
fn spawn(&self, future: impl Future<Output = ()> + Send + 'static) {
let _ = self.0.spawn(future);
}
fn enter<R>(&self, f: impl FnOnce() -> R) -> R {
let _guard = self.0.enter();
f()
}
}