10 releases (1 stable)
1.0.0 | Dec 17, 2019 |
---|---|
0.3.0 | Nov 19, 2019 |
0.2.6 | Sep 25, 2019 |
0.1.0 | Sep 15, 2019 |
#1122 in Asynchronous
2,010 downloads per month
Used in 16 crates
(4 directly)
17KB
315 lines
broadcaster
broadcaster provides a wrapper for any Stream and Sink implementing the mpsc pattern to enable broadcasting items. This means that any item sent will be received by every receiver, not just the first to check (like most mpmc streams). As an example:
use broadcaster::BroadcastChannel;
use futures_util::StreamExt;
let mut chan = BroadcastChannel::new();
chan.send(&5i32).await?;
assert_eq!(chan.next().await, Some(5));
let mut chan2 = chan.clone();
chan2.send(&6i32).await?;
assert_eq!(chan.next().await, Some(6));
assert_eq!(chan2.next().await, Some(6));
lib.rs
:
broadcaster provides a wrapper for any Stream and Sink implementing the mpsc pattern to enable broadcasting items. This means that any item sent will be received by every receiver, not just the first to check (like most mpmc streams). As an example:
use broadcaster::BroadcastChannel;
use futures_util::StreamExt;
let mut chan = BroadcastChannel::new();
chan.send(&5i32).await?;
assert_eq!(chan.next().await, Some(5));
let mut chan2 = chan.clone();
chan2.send(&6i32).await?;
assert_eq!(chan.next().await, Some(6));
assert_eq!(chan2.next().await, Some(6));
Dependencies
~0.6–1.1MB
~18K SLoC