#native #sync #wait-object

sync-wait-object

Synchronous Wait Object (abstraction over Mutex & CondVar)

2 unstable releases

0.2.0 Jan 22, 2023
0.1.0 Jan 20, 2023

#196 in Windows APIs

Download history 22/week @ 2024-07-28 15/week @ 2024-08-04 11/week @ 2024-08-11 15/week @ 2024-08-18 16/week @ 2024-08-25 35/week @ 2024-09-01 12/week @ 2024-09-08 59/week @ 2024-09-22 27/week @ 2024-09-29 14/week @ 2024-10-06 44/week @ 2024-10-13 57/week @ 2024-10-20 164/week @ 2024-10-27 25/week @ 2024-11-03

290 downloads per month
Used in native-timer

MIT license

20KB
266 lines

Wait Object based on Mutex and Condvar

Provide an abstraction over Condvar + Mutex usage, as provided by the Rust document in Condvar.

The library provides three main types: WaitEvent, ManualResetEvent, and AutoResetEvent. WaitEvent is the core abstraction mentioned. ManualResetEvent and AutoResetEvent are just a specialization for bool type.

When compiling with Windows platform, the lib also provides windows module for native implementation of ManualResetEvent and AutoResetEvent.

Example of the abstraction provided:

use sync_wait_object::WaitEvent;
use std::thread;

let wait3 = WaitEvent::new_init(0);
let mut wait_handle = wait3.clone();

thread::spawn(move || {
    for i in 1..=3 {
        wait_handle.set_state(i).unwrap();
    }
});

let timeout = std::time::Duration::from_secs(1);
let r#final = *wait3.wait(Some(timeout), |i| *i == 3).unwrap();
let current = *wait3.value().unwrap();
assert_eq!(r#final, 3);
assert_eq!(current, 3);

The second is to wait and then reset the value to a desired state.

use sync_wait_object::WaitEvent;
use std::thread;

let wait3 = WaitEvent::new_init(0);
let mut wait_handle = wait3.clone();

thread::spawn(move || {
    for i in 1..=3 {
        wait_handle.set_state(i).unwrap();
    }
});

let timeout = std::time::Duration::from_secs(1);
let r#final = wait3.wait_reset(Some(timeout), || 1, |i| *i == 3).unwrap();
let current = *wait3.value().unwrap();
assert_eq!(r#final, 3);
assert_eq!(current, 1);

Dependencies

~0–38MB
~524K SLoC