Skip to content

Synchronization primitives for both web and native.

Notifications You must be signed in to change notification settings

DouglasDwyer/wasm_sync

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 

Repository files navigation

wasm_sync

Crates.io Docs.rs

wasm_sync offers synchronization primitives that work in both browser and native contexts.

In web browsers, use of atomic wait instructions on the main thread causes an error. This prevents the use of standard library synchronization primitives within web contexts. wasm_sync solves this problem by busy-spinning on the main thread. Other threads, like dedicated web workers, still use atomic wait instructions.

On native platforms, wasm_sync simply re-exports the standard library's synchronization primitives.

Supported primitives

  • wasm_sync::Condvar
  • wasm_sync::Mutex
  • wasm_sync::RwLock
  • wasm_sync::Once
  • wasm_sync::OnceLock

Usage

Instead of importing a standard library primitive, import the wasm_sync variant. For example:

use std::sync::Arc;
use std::thread;
use wasm_sync::Mutex;

let mutex = Arc::new(Mutex::new(0));
let c_mutex = Arc::clone(&mutex);

thread::spawn(move || {
    *c_mutex.lock().unwrap() = 10;
}).join().expect("thread::spawn failed");
assert_eq!(*mutex.lock().unwrap(), 10);

About

Synchronization primitives for both web and native.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages