use async_trait::async_trait; use messagebus::{error::Error, receivers, AsyncBatchSynchronizedHandler, BatchSynchronizedHandler, Bus}; struct TmpReceiver; #[async_trait] impl AsyncBatchSynchronizedHandler for TmpReceiver { type Error = Error; type Response = (); async fn handle(&mut self, msg: Vec, _bus: &Bus) -> Result, Self::Error> { println!("---> [i32; {}] {:?}", msg.len(), msg); Ok(vec![]) } } impl BatchSynchronizedHandler for TmpReceiver { type Error = Error; type Response = (); fn handle(&mut self, msg: Vec, _bus: &Bus) -> Result, Self::Error> { println!("---> [i16; {}] {:?}", msg.len(), msg); Ok(vec![]) } } #[tokio::main] async fn main() { let (b, poller) = Bus::build() .register_unsync(TmpReceiver) .subscribe::, _, _>(16, Default::default()) .subscribe::, _, _>(16, Default::default()) .done() .build(); for i in 1..100 { b.send(i).await.unwrap(); } b.send(1i16).await.unwrap(); b.send(2i16).await.unwrap(); b.send(3i16).await.unwrap(); b.send(4i16).await.unwrap(); b.send(5i16).await.unwrap(); b.send(6i16).await.unwrap(); b.send(7i16).await.unwrap(); println!("flush"); b.flush().await; println!("close"); b.close().await; println!("closed"); poller.await; println!("[done]"); }