mirror of
https://github.com/fluencelabs/rust-libp2p
synced 2025-06-27 16:51:34 +00:00
Executor + Send (#1399)
This commit is contained in:
@ -309,7 +309,7 @@ where
|
||||
{
|
||||
/// Creates a new empty collection. If `executor` is `Some`, uses the given executor to spawn
|
||||
/// tasks. Otherwise, runs tasks locally.
|
||||
pub fn new(executor: Option<Box<dyn Executor>>) -> Self {
|
||||
pub fn new(executor: Option<Box<dyn Executor + Send>>) -> Self {
|
||||
CollectionStream {
|
||||
inner: tasks::Manager::new(executor),
|
||||
nodes: Default::default(),
|
||||
|
@ -688,7 +688,7 @@ where
|
||||
TPeerId: Eq + Hash + Clone,
|
||||
{
|
||||
/// Creates a new node events stream.
|
||||
pub fn new(transport: TTrans, local_peer_id: TPeerId, executor: Option<Box<dyn Executor>>) -> Self {
|
||||
pub fn new(transport: TTrans, local_peer_id: TPeerId, executor: Option<Box<dyn Executor + Send>>) -> Self {
|
||||
// TODO: with_capacity?
|
||||
Network {
|
||||
listeners: ListenersStream::new(transport),
|
||||
@ -706,7 +706,7 @@ where
|
||||
|
||||
/// Creates a new node event stream with incoming connections limit.
|
||||
pub fn new_with_incoming_limit(transport: TTrans,
|
||||
local_peer_id: TPeerId, executor: Option<Box<dyn Executor>>, incoming_limit: Option<u32>) -> Self
|
||||
local_peer_id: TPeerId, executor: Option<Box<dyn Executor + Send>>, incoming_limit: Option<u32>) -> Self
|
||||
{
|
||||
Network {
|
||||
incoming_limit,
|
||||
|
@ -65,7 +65,7 @@ pub struct Manager<I, O, H, E, HE, T, C = PeerId> {
|
||||
|
||||
/// Custom executor where we spawn the nodes' tasks. If `None`, then we push tasks to the
|
||||
/// `local_spawns` list instead.
|
||||
executor: Option<Box<dyn Executor>>,
|
||||
executor: Option<Box<dyn Executor + Send>>,
|
||||
|
||||
/// If no executor is available, we move tasks to this set, and futures are polled on the
|
||||
/// current thread instead.
|
||||
@ -136,7 +136,7 @@ pub enum Event<'a, I, O, H, E, HE, T, C = PeerId> {
|
||||
impl<I, O, H, E, HE, T, C> Manager<I, O, H, E, HE, T, C> {
|
||||
/// Creates a new task manager. If `Some` is passed, uses the given executor to spawn tasks.
|
||||
/// Otherwise, background tasks are executed locally when you call `poll`.
|
||||
pub fn new(executor: Option<Box<dyn Executor>>) -> Self {
|
||||
pub fn new(executor: Option<Box<dyn Executor + Send>>) -> Self {
|
||||
let (tx, rx) = mpsc::channel(1);
|
||||
Self {
|
||||
tasks: FnvHashMap::default(),
|
||||
|
@ -572,7 +572,7 @@ impl<'a> PollParameters for SwarmPollParameters<'a> {
|
||||
|
||||
pub struct SwarmBuilder<TTransport, TBehaviour> {
|
||||
incoming_limit: Option<u32>,
|
||||
executor: Option<Box<dyn Executor>>,
|
||||
executor: Option<Box<dyn Executor + Send>>,
|
||||
local_peer_id: PeerId,
|
||||
transport: TTransport,
|
||||
behaviour: TBehaviour,
|
||||
@ -626,13 +626,13 @@ where TBehaviour: NetworkBehaviour,
|
||||
/// Sets the executor to use to spawn background tasks.
|
||||
///
|
||||
/// By default, uses a threads pool.
|
||||
pub fn executor(mut self, executor: impl Executor + 'static) -> Self {
|
||||
pub fn executor(mut self, executor: impl Executor + Send + 'static) -> Self {
|
||||
self.executor = Some(Box::new(executor));
|
||||
self
|
||||
}
|
||||
|
||||
/// Shortcut for calling `executor` with an object that calls the given closure.
|
||||
pub fn executor_fn(mut self, executor: impl Fn(Pin<Box<dyn Future<Output = ()> + Send>>) + 'static) -> Self {
|
||||
pub fn executor_fn(mut self, executor: impl Fn(Pin<Box<dyn Future<Output = ()> + Send>>) + Send + 'static) -> Self {
|
||||
struct SpawnImpl<F>(F);
|
||||
impl<F: Fn(Pin<Box<dyn Future<Output = ()> + Send>>)> Executor for SpawnImpl<F> {
|
||||
fn exec(&self, f: Pin<Box<dyn Future<Output = ()> + Send>>) {
|
||||
|
Reference in New Issue
Block a user