cond_sync 0.2.1

Hides the boilerplate code needed with std::sync::Condvar
Documentation
  • Coverage
  • 100%
    19 out of 19 items documented1 out of 13 items with examples
  • Size
  • Source code size: 24.74 kB This is the summed size of all the files inside the crates.io package for this release.
  • Documentation size: 883.63 kB This is the summed size of all files generated by rustdoc for all configured targets
  • Links
  • Repository
  • crates.io
  • Dependencies
  • Versions
  • Owners
  • emabee

cond_sync

A thin wrapper around std::sync::CondVar and Mutex that enhances readability when synchronizing threads.

Latest version Documentation License Build unsafe forbidden

Usage

Add cond_sync to the dependencies in your project's Cargo.toml:

[dependencies]
cond_sync = "0.2"

Example

use cond_sync::{CondSync, Other};

let cond_sync = CondSync::new(0_usize);

for i in 0..5 {
    let cond_sync_t = cond_sync.clone();
    std::thread::spawn(move || {
        // ...initialize...
        cond_sync_t.modify_and_notify(|v| *v += 1, Other::One).unwrap();
        // ...do real work...
    });
}
// wait until all threads are initialized
cond_sync.wait_until(|v| *v == 5).unwrap();

// ...

Dependencies

No dependencies.

Versions

See the change log for more details.