summaryrefslogtreecommitdiffstats
path: root/futures/src/runtime.rs
diff options
context:
space:
mode:
authorLibravatar Héctor Ramón Jiménez <hector0193@gmail.com>2020-01-19 10:17:08 +0100
committerLibravatar Héctor Ramón Jiménez <hector0193@gmail.com>2020-01-19 10:17:44 +0100
commitb5b17ed4d800c03beb3ad535d1069a7784e8dc1d (patch)
treeb9e6477bd11bd6784f8ee61e818b5f5ff1a44318 /futures/src/runtime.rs
parentd50ff9b5d97d9c3d6c6c70a9b4efe764b6126c86 (diff)
downloadiced-b5b17ed4d800c03beb3ad535d1069a7784e8dc1d.tar.gz
iced-b5b17ed4d800c03beb3ad535d1069a7784e8dc1d.tar.bz2
iced-b5b17ed4d800c03beb3ad535d1069a7784e8dc1d.zip
Create `iced_futures` and wire everything up
Diffstat (limited to '')
-rw-r--r--futures/src/runtime.rs (renamed from core/src/runtime.rs)13
1 files changed, 9 insertions, 4 deletions
diff --git a/core/src/runtime.rs b/futures/src/runtime.rs
index 31234d11..bc1ad8ac 100644
--- a/core/src/runtime.rs
+++ b/futures/src/runtime.rs
@@ -1,3 +1,4 @@
+//! Run commands and subscriptions.
mod executor;
pub use executor::Executor;
@@ -10,8 +11,8 @@ use std::marker::PhantomData;
#[derive(Debug)]
pub struct Runtime<Hasher, Event, Executor, Receiver, Message> {
executor: Executor,
- subscriptions: subscription::Tracker<Hasher, Event>,
receiver: Receiver,
+ subscriptions: subscription::Tracker<Hasher, Event>,
_message: PhantomData<Message>,
}
@@ -28,15 +29,19 @@ where
+ 'static,
Message: Send + 'static,
{
- pub fn new(receiver: Receiver) -> Self {
+ pub fn new(executor: Executor, receiver: Receiver) -> Self {
Self {
- executor: Executor::new(),
- subscriptions: subscription::Tracker::new(),
+ executor,
receiver,
+ subscriptions: subscription::Tracker::new(),
_message: PhantomData,
}
}
+ pub fn enter<R>(&self, f: impl FnOnce() -> R) -> R {
+ self.executor.enter(f)
+ }
+
pub fn spawn(&mut self, command: Command<Message>) {
use futures::{FutureExt, SinkExt};