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
76
77
78
79
#[cfg(all(feature = "_tls-native-tls"))]
pub use native_tls;
pub use tokio::{
self, fs, io::AsyncRead, io::AsyncReadExt, io::AsyncWrite, io::AsyncWriteExt, io::ReadBuf,
net::TcpStream, runtime::Handle, task::spawn, task::yield_now, time::sleep, time::timeout,
};
#[cfg(all(unix, any(feature = "_rt-tokio")))]
pub use tokio::net::UnixStream;
pub use tokio_runtime::{block_on, enter_runtime};
mod tokio_runtime {
use once_cell::sync::Lazy;
use tokio::runtime::{self, Runtime};
static RUNTIME: Lazy<Runtime> = Lazy::new(|| {
runtime::Builder::new_multi_thread()
.enable_io()
.enable_time()
.build()
.expect("failed to initialize Tokio runtime")
});
pub fn block_on<F: std::future::Future>(future: F) -> F::Output {
RUNTIME.block_on(future)
}
pub fn enter_runtime<F, R>(f: F) -> R
where
F: FnOnce() -> R,
{
let _rt = RUNTIME.enter();
f()
}
}
#[cfg(all(
feature = "_tls-native-tls",
any(feature = "_rt-tokio"),
not(any(feature = "_tls-rustls")),
))]
pub use tokio_native_tls::{TlsConnector, TlsStream};
#[cfg(all(
feature = "_tls-rustls",
any(feature = "_rt-tokio"),
not(any(feature = "_tls-native-tls")),
))]
pub use tokio_rustls::{client::TlsStream, TlsConnector};
#[macro_export]
macro_rules! blocking {
($($expr:tt)*) => {
$crate::tokio::task::spawn_blocking(move || { $($expr)* })
.await.expect("Blocking task failed to complete.")
};
}
#[macro_export]
macro_rules! block_on {
($ex:expr) => {
tokio::runtime::Builder::new_multi_thread()
.enable_all()
.build()
.unwrap()
.block_on($ex);
};
}