Module Mutex
Contents
Instructions: Use this module in your project
In the IDE (CLion, Visual Studio Code, Xcode, etc.) you use for your DkSDK project:
Add the following to your project's
dependencies/CMakeLists.txt
:DkSDKProject_DeclareAvailable(ocaml CONSTRAINT "= 4.14.0" FINDLIBS str unix runtime_events threads dynlink) DkSDKProject_MakeAvailable(ocaml)
Add the
Findlib::ocaml
library to any desired targets insrc/*/CMakeLists.txt
:target_link_libraries(YourPackage_YourLibraryName # ... existing libraries, if any ... Findlib::ocaml)
Click your IDE's
Build
button
Not using DkSDK?
FIRST, do one or all of the following:
Run:
opam install ocaml.4.14.0
Edit your
dune-project
and add:(package (name YourExistingPackage) (depends ; ... existing dependenices ... (ocaml (>= 4.14.0))))
Then run:
dune build *.opam # if this fails, run: dune build
Edit your
<package>.opam
file and add:depends: [ # ... existing dependencies ... "ocaml" {>= "4.14.0"} ]
Then run:
opam install . --deps-only
FINALLY, add the unix threads
library to any desired (library)
and/or (executable)
targets in your **/dune
files:
(library
(name YourLibrary)
; ... existing library options ...
(libraries
; ... existing libraries ...
unix threads))
(executable
(name YourExecutable)
; ... existing executable options ...
(libraries
; ... existing libraries ...
unix threads))
type
t
The type of mutexes.
val
create : ``unit
->
t
Return a new mutex.
val
lock :
t
->
unit
Lock the given mutex. Only one thread can have the mutex locked at any time. A thread that attempts to lock a mutex already locked by another thread will suspend until the other thread unlocks the mutex.
-
raises Sys_error
if the mutex is already locked by the thread calling
Mutex.lock
. -
before 4.12
Sys_error
was not raised for recursive locking (platform-dependent behaviour)
val
try_lock :
t
->
bool
Same as Mutex.lock
, but does not suspend the calling
thread if the mutex is already locked: just return false
immediately
in that case. If the mutex is unlocked, lock it and return true
.
val
unlock :
t
->
unit
Unlock the given mutex. Other threads suspended trying to lock the mutex
will restart. The mutex must have been previously locked by the thread
that calls Mutex.unlock
.
-
raises Sys_error
if the mutex is unlocked or was locked by another thread.
-
before 4.12
Sys_error
was not raised when unlocking an unlocked mutex or when unlocking a mutex from a different thread.