mirror of
https://github.com/0glabs/0g-storage-node.git
synced 2025-04-04 15:35:18 +00:00
43 lines
1007 B
Rust
43 lines
1007 B
Rust
///! A simple trait to allow generic executors or wrappers for spawning the discv5 tasks.
|
|
use std::future::Future;
|
|
use std::pin::Pin;
|
|
|
|
pub trait Executor: ExecutorClone {
|
|
/// Run the given future in the background until it ends.
|
|
fn spawn(&self, future: Pin<Box<dyn Future<Output = ()> + Send>>);
|
|
}
|
|
|
|
pub trait ExecutorClone {
|
|
fn clone_box(&self) -> Box<dyn Executor + Send + Sync>;
|
|
}
|
|
|
|
impl<T> ExecutorClone for T
|
|
where
|
|
T: 'static + Executor + Clone + Send + Sync,
|
|
{
|
|
fn clone_box(&self) -> Box<dyn Executor + Send + Sync> {
|
|
Box::new(self.clone())
|
|
}
|
|
}
|
|
|
|
impl Clone for Box<dyn Executor + Send + Sync> {
|
|
fn clone(&self) -> Box<dyn Executor + Send + Sync> {
|
|
self.clone_box()
|
|
}
|
|
}
|
|
|
|
#[derive(Clone)]
|
|
pub struct TokioExecutor;
|
|
|
|
impl Executor for TokioExecutor {
|
|
fn spawn(&self, future: Pin<Box<dyn Future<Output = ()> + Send>>) {
|
|
tokio::task::spawn(future);
|
|
}
|
|
}
|
|
|
|
impl Default for TokioExecutor {
|
|
fn default() -> Self {
|
|
TokioExecutor
|
|
}
|
|
}
|