module CCLock:sig
..end
A value wrapped into a Mutex, for more safety.
Since 0.8
type 'a
t
val create : 'a -> 'a t
val with_lock : 'a t -> ('a -> 'b) -> 'b
with_lock l f
runs f x
where x
is the value protected with
the lock l
, in a critical section. If f x
fails, with_lock l f
fails too but the lock is releasedval try_with_lock : 'a t -> ('a -> 'b) -> 'b option
try_with_lock l f
runs f x
in a critical section if l
is not
locked. x
is the value protected by the lock l
. If f x
fails, try_with_lock l f
fails too but the lock is releasedmodule LockRef:sig
..end
val with_lock_as_ref : 'a t -> f:('a LockRef.t -> 'b) -> 'b
with_lock_as_ref l f
calls f
with a reference-like object
that allows to manipulate the value of l
safely.
The object passed to f
must not escape the function callval update : 'a t -> ('a -> 'a) -> unit
update l f
replaces the content x
of l
with f x
, atomicallyval update_map : 'a t -> ('a -> 'a * 'b) -> 'b
update_map l f
computes x', y = f (get l)
, then puts x'
in l
and returns y
val mutex : 'a t -> Mutex.t
val get : 'a t -> 'a
val set : 'a t -> 'a -> unit
val incr : int t -> unit
val decr : int t -> unit
val incr_then_get : int t -> int
incr_then_get x
increments x
, and return its new valueval get_then_incr : int t -> int
get_then_incr x
increments x
, and return its previous valueval decr_then_get : int t -> int
decr_then_get x
decrements x
, and return its new valueval get_then_decr : int t -> int
get_then_decr x
decrements x
, and return its previous valueval get_then_set : bool t -> bool
get_then_set b
sets b
to true
, and return the old valueval get_then_clear : bool t -> bool
get_then_clear b
sets b
to false
, and return the old value