diff --git a/src/dealer.rs b/src/dealer.rs index 356c3fe..13df682 100644 --- a/src/dealer.rs +++ b/src/dealer.rs @@ -31,7 +31,7 @@ impl Drop for DealerSocket { #[async_trait] impl Socket for DealerSocket { fn with_options(options: SocketOptions) -> Self { - let fair_queue = FairQueue::new(true); + let fair_queue = FairQueue::new(options.block_on_no_clients); Self { backend: Arc::new(GenericSocketBackend::with_options( Some(fair_queue.inner()), diff --git a/src/lib.rs b/src/lib.rs index 1d0676d..902e27e 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -169,9 +169,19 @@ pub enum SocketEvent { Disconnected(PeerIdentity), } -#[derive(Default)] +#[derive(Debug, Clone)] pub struct SocketOptions { pub(crate) peer_id: Option, + pub(crate) block_on_no_clients: bool, +} + +impl Default for SocketOptions { + fn default() -> Self { + Self { + peer_id: Default::default(), + block_on_no_clients: true, + } + } } impl SocketOptions { @@ -179,6 +189,10 @@ impl SocketOptions { self.peer_id = Some(peer_id); self } + pub fn block_on_no_clients(&mut self, block_on_no_clients: bool) -> &mut Self { + self.block_on_no_clients = block_on_no_clients; + self + } } #[async_trait] diff --git a/src/pull.rs b/src/pull.rs index d92297e..15b16d9 100644 --- a/src/pull.rs +++ b/src/pull.rs @@ -25,7 +25,7 @@ pub struct PullSocket { #[async_trait] impl Socket for PullSocket { fn with_options(options: SocketOptions) -> Self { - let fair_queue = FairQueue::new(true); + let fair_queue = FairQueue::new(options.block_on_no_clients); Self { backend: Arc::new(GenericSocketBackend::with_options( Some(fair_queue.inner()), diff --git a/src/rep.rs b/src/rep.rs index 8867df1..9760ace 100644 --- a/src/rep.rs +++ b/src/rep.rs @@ -43,7 +43,7 @@ impl Drop for RepSocket { #[async_trait] impl Socket for RepSocket { fn with_options(options: SocketOptions) -> Self { - let fair_queue = FairQueue::new(true); + let fair_queue = FairQueue::new(options.block_on_no_clients); Self { backend: Arc::new(RepSocketBackend { peers: DashMap::new(), diff --git a/src/router.rs b/src/router.rs index b64c954..803761f 100644 --- a/src/router.rs +++ b/src/router.rs @@ -32,7 +32,7 @@ impl Drop for RouterSocket { #[async_trait] impl Socket for RouterSocket { fn with_options(options: SocketOptions) -> Self { - let fair_queue = FairQueue::new(true); + let fair_queue = FairQueue::new(options.block_on_no_clients); Self { backend: Arc::new(GenericSocketBackend::with_options( Some(fair_queue.inner()), diff --git a/src/sub.rs b/src/sub.rs index 85d14e3..5c03f8a 100644 --- a/src/sub.rs +++ b/src/sub.rs @@ -156,7 +156,7 @@ impl SubSocket { #[async_trait] impl Socket for SubSocket { fn with_options(options: SocketOptions) -> Self { - let fair_queue = FairQueue::new(true); + let fair_queue = FairQueue::new(options.block_on_no_clients); Self { backend: Arc::new(SubSocketBackend::with_options( Some(fair_queue.inner()),