cleaner impl, tests

This commit is contained in:
Robin Müller 2023-07-07 20:04:33 +02:00
parent b8c338c91c
commit fd31adc19e
Signed by: muellerr
GPG Key ID: A649FB78196E3849

View File

@ -122,6 +122,10 @@ pub mod stdmod {
macro_rules! sync_clonable_seq_counter_impl { macro_rules! sync_clonable_seq_counter_impl {
($($ty: ident,)+) => { ($($ty: ident,)+) => {
$(paste! { $(paste! {
/// These sequence counters can be shared between threads and can also be
/// configured to wrap around at specified maximum values. Please note that
/// that the API provided by this class will not panic und [Mutex] lock errors,
/// but it will yield 0 for the getter functions.
#[derive(Clone, Default)] #[derive(Clone, Default)]
pub struct [<SeqCountProviderSync $ty:upper>] { pub struct [<SeqCountProviderSync $ty:upper>] {
seq_count: Arc<Mutex<$ty>>, seq_count: Arc<Mutex<$ty>>,
@ -142,7 +146,10 @@ pub mod stdmod {
} }
impl SequenceCountProviderCore<$ty> for [<SeqCountProviderSync $ty:upper>] { impl SequenceCountProviderCore<$ty> for [<SeqCountProviderSync $ty:upper>] {
fn get(&self) -> $ty { fn get(&self) -> $ty {
*self.seq_count.lock().unwrap() match self.seq_count.lock() {
Ok(counter) => *counter,
Err(_) => 0
}
} }
fn increment(&self) { fn increment(&self) {
@ -150,14 +157,18 @@ pub mod stdmod {
} }
fn get_and_increment(&self) -> $ty { fn get_and_increment(&self) -> $ty {
let mut counter = self.seq_count.lock().unwrap(); match self.seq_count.lock() {
let current_val = *counter; Ok(mut counter) => {
if *counter == self.max_val { let val = *counter;
*counter = 0; if val == self.max_val {
} else { *counter = 0;
*counter += 1; } else {
*counter += 1;
}
val
}
Err(_) => 0,
} }
current_val
} }
} }
})+ })+