1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
type t = Unix.file_descr
let create_internal op path =
Path.mkdir_p (Path.parent_exn path);
let fd =
Unix.openfile (Path.to_string path) [ Unix.O_CREAT; Unix.O_RDWR ] 0o600
and pid = string_of_int (Unix.getpid ()) in
let pid_len = String.length pid in
match
Unix.lockf fd op 0;
assert (Unix.single_write_substring fd pid 0 pid_len = pid_len)
with
| () -> Some fd
| exception Unix.Unix_error (EAGAIN, _, _) ->
Unix.close fd;
None
| exception e ->
Unix.close fd;
Exn.reraise e
let create path = Option.value_exn (create_internal F_LOCK path)
let try_create = create_internal F_TLOCK
let unlock fd = Unix.close fd