2018-12-09 19:55:40 -08:00
|
|
|
//! A runtime implementation that runs everything on the current thread.
|
|
|
|
|
2019-11-26 10:14:21 +06:00
|
|
|
#[cfg(not(test))] // Work around for rust-lang/rust#62127
|
2019-11-25 21:49:11 +06:00
|
|
|
pub use actix_macros::{main, test};
|
|
|
|
|
2018-12-09 19:55:40 -08:00
|
|
|
mod arbiter;
|
|
|
|
mod builder;
|
|
|
|
mod runtime;
|
|
|
|
mod system;
|
|
|
|
|
2018-12-09 20:30:04 -08:00
|
|
|
pub use self::arbiter::Arbiter;
|
2018-12-09 19:55:40 -08:00
|
|
|
pub use self::builder::{Builder, SystemRunner};
|
2019-03-06 10:24:58 -08:00
|
|
|
pub use self::runtime::Runtime;
|
2018-12-09 19:55:40 -08:00
|
|
|
pub use self::system::System;
|
2018-12-09 20:30:04 -08:00
|
|
|
|
2019-03-28 03:56:52 -07:00
|
|
|
#[doc(hidden)]
|
|
|
|
pub use actix_threadpool as blocking;
|
|
|
|
|
2018-12-09 20:30:04 -08:00
|
|
|
/// Spawns a future on the current arbiter.
|
|
|
|
///
|
|
|
|
/// # Panics
|
|
|
|
///
|
|
|
|
/// This function panics if actix system is not running.
|
|
|
|
pub fn spawn<F>(f: F)
|
|
|
|
where
|
2019-11-14 18:38:24 +06:00
|
|
|
F: futures::Future<Output = ()> + 'static,
|
2018-12-09 20:30:04 -08:00
|
|
|
{
|
|
|
|
if !System::is_set() {
|
|
|
|
panic!("System is not running");
|
|
|
|
}
|
|
|
|
|
|
|
|
Arbiter::spawn(f);
|
|
|
|
}
|
2019-11-26 08:12:16 +06:00
|
|
|
|
|
|
|
/// Utilities for tracking time.
|
|
|
|
pub mod time {
|
|
|
|
use std::time::{Duration, Instant};
|
|
|
|
|
|
|
|
pub use tokio_timer::Interval;
|
|
|
|
pub use tokio_timer::{delay, delay_for, Delay};
|
2019-11-26 09:04:14 +06:00
|
|
|
pub use tokio_timer::{timeout, Timeout};
|
2019-11-26 08:12:16 +06:00
|
|
|
|
|
|
|
/// Creates new `Interval` that yields with interval of `duration`. The first
|
|
|
|
/// tick completes immediately.
|
|
|
|
pub fn interval(duration: Duration) -> Interval {
|
|
|
|
Interval::new(Instant::now(), duration)
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Creates new `Interval` that yields with interval of `period` with the
|
|
|
|
/// first tick completing at `at`.
|
|
|
|
pub fn interval_at(start: Instant, duration: Duration) -> Interval {
|
|
|
|
Interval::new(start, duration)
|
|
|
|
}
|
|
|
|
}
|