1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
//! The runtime of compio.
//! We don't expose the runtime struct because there could be only one runtime
//! in each thread.
//!
//! ```
//! let ans = compio_runtime::block_on(async {
//! println!("Hello world!");
//! 42
//! });
//! assert_eq!(ans, 42);
//! ```
#![cfg_attr(feature = "once_cell_try", feature(once_cell_try))]
#![warn(missing_docs)]
mod attacher;
mod key;
pub(crate) mod runtime;
#[cfg(feature = "event")]
pub mod event;
#[cfg(feature = "time")]
pub mod time;
use std::{future::Future, io};
use async_task::Task;
pub use attacher::Attacher;
use compio_buf::BufResult;
use compio_driver::{OpCode, RawFd};
pub(crate) use key::Key;
use runtime::Runtime;
thread_local! {
pub(crate) static RUNTIME: Runtime = Runtime::new().expect("cannot create compio runtime");
}
/// Start a compio runtime and block on the future till it completes.
pub fn block_on<F: Future>(future: F) -> F::Output {
RUNTIME.with(|runtime| runtime.block_on(future))
}
/// Spawns a new asynchronous task, returning a [`Task`] for it.
///
/// Spawning a task enables the task to execute concurrently to other tasks.
/// There is no guarantee that a spawned task will execute to completion.
///
/// ```
/// compio_runtime::block_on(async {
/// let task = compio_runtime::spawn(async {
/// println!("Hello from a spawned task!");
/// 42
/// });
///
/// assert_eq!(task.await, 42);
/// })
/// ```
pub fn spawn<F: Future + 'static>(future: F) -> Task<F::Output> {
RUNTIME.with(|runtime| runtime.spawn(future))
}
/// Attach a raw file descriptor/handle/socket to the runtime.
///
/// You only need this when authoring your own high-level APIs. High-level
/// resources in this crate are attached automatically.
pub fn attach(fd: RawFd) -> io::Result<()> {
RUNTIME.with(|runtime| runtime.attach(fd))
}
/// Submit an operation to the runtime.
///
/// You only need this when authoring your own [`OpCode`].
pub fn submit<T: OpCode + 'static>(op: T) -> impl Future<Output = BufResult<usize, T>> {
RUNTIME.with(|runtime| runtime.submit(op))
}