From 91de538c9802e7c45cadc5391450631c74f593d2 Mon Sep 17 00:00:00 2001 From: Jason Toffaletti Date: Mon, 11 Nov 2013 13:33:43 -0800 Subject: add rust_trylock_little_lock Try to acquire lock and succeed only if lock is not already held. Uses TryEnterCriticalSection or pthread_mutex_trylock. --- src/libstd/unstable/sync.rs | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) (limited to 'src/libstd') diff --git a/src/libstd/unstable/sync.rs b/src/libstd/unstable/sync.rs index a08b914ca31..0e1f5fc1bdc 100644 --- a/src/libstd/unstable/sync.rs +++ b/src/libstd/unstable/sync.rs @@ -13,7 +13,7 @@ use cell::Cell; use comm; use libc; use ptr; -use option::*; +use option::{Option,Some,None}; use task; use unstable::atomics::{AtomicOption,AtomicUint,Acquire,Release,Relaxed,SeqCst}; use unstable::finally::Finally; @@ -354,6 +354,20 @@ impl LittleLock { } } + pub unsafe fn try_lock(&self, f: &fn() -> T) -> Option { + do atomically { + if rust_trylock_little_lock(self.l) { + Some(do (|| { + f() + }).finally { + rust_unlock_little_lock(self.l); + }) + } else { + None + } + } + } + pub unsafe fn signal(&self) { rust_signal_little_lock(self.l); } @@ -478,6 +492,7 @@ impl Exclusive { extern { fn rust_create_little_lock() -> rust_little_lock; fn rust_destroy_little_lock(lock: rust_little_lock); + fn rust_trylock_little_lock(lock: rust_little_lock) -> bool; fn rust_lock_little_lock(lock: rust_little_lock); fn rust_unlock_little_lock(lock: rust_little_lock); fn rust_signal_little_lock(lock: rust_little_lock); -- cgit 1.4.1-3-g733a5