//! Abstracts out the APIs necessary to `Runtime` for integrating the I/O //! driver. When the `time` feature flag is **not** enabled. These APIs are //! shells. This isolates the complexity of dealing with conditional //! compilation. /// Re-exported for convenience. pub(crate) use std::io::Result; pub(crate) use variant::*; #[cfg(feature = "io-driver")] mod variant { use crate::io::driver; use crate::park::{Either, ParkThread}; use std::io; /// The driver value the runtime passes to the `timer` layer. /// /// When the `io-driver` feature is enabled, this is the "real" I/O driver /// backed by Mio. Without the `io-driver` feature, this is a thread parker /// backed by a condition variable. pub(crate) type Driver = Either; /// The handle the runtime stores for future use. /// /// When the `io-driver` feature is **not** enabled, this is `()`. pub(crate) type Handle = Option; pub(crate) fn create_driver(enable: bool) -> io::Result<(Driver, Handle)> { #[cfg(loom)] assert!(!enable); if enable { let driver = driver::Driver::new()?; let handle = driver.handle(); Ok((Either::A(driver), Some(handle))) } else { let driver = ParkThread::new(); Ok((Either::B(driver), None)) } } } #[cfg(not(feature = "io-driver"))] mod variant { use crate::park::ParkThread; use std::io; /// I/O is not enabled, use a condition variable based parker pub(crate) type Driver = ParkThread; /// There is no handle pub(crate) type Handle = (); pub(crate) fn create_driver(_enable: bool) -> io::Result<(Driver, Handle)> { let driver = ParkThread::new(); Ok((driver, ())) } }