1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
//! mpmc-ringbuf focuses on offering a easy and efficient way to share data between different instance.
//! And we offer the different mode `Fixed`,`Dynamic` to satisfy the demand.
//!
//! see more detail on core module pages
//!
//! simple example
//!
//! single thread
//! ```rust
//!  use mpmc_ringbuf::core::MsgQueue;
//!  let mut msg_queue: MsgQueue<u8> = MsgQueue::new();
//!  let mut writer1 = msg_queue.add_producer();
//!  let mut read1 = msg_queue.add_consumer();
//!  writer1.write(vec![10; 100]);
//!  assert_eq!(read1.size(), 100);
//!  let mut read2 = msg_queue.add_consumer();
//!  assert_eq!(read2.size(), 0);
//!  assert_eq!(msg_queue.get_consumer_count(), 2);
//!  writer1.write(vec![0; 100]);
//!  assert_eq!(read1.size(), 200);
//!  assert_eq!(read2.size(), 100);
//!  read2.read(50);
//!  assert_eq!(read1.size(), 200);
//!  assert_eq!(read2.size(), 50);
//! ```
//!
#![feature(core_panic)]
pub mod core;