This file is indexed.

/usr/lib/ocaml/sqlexpr/sqlexpr_concurrency.mli is in libsqlexpr-ocaml-dev 0.4.1-1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 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
28
29
30
31
32
33
34
35
36
37
(** Concurrency monad. *)

(** The THREAD monad. *)
module type THREAD =
sig
  type 'a t
  val return : 'a -> 'a t
  val bind : 'a t -> ('a -> 'b t) -> 'b t
  val fail : exn -> 'a t
  val catch : (unit -> 'a t) -> (exn -> 'a t) -> 'a t
  val finalize : (unit -> 'a t) -> (unit -> unit t) -> 'a t
  val sleep : float -> unit t
  val auto_yield : float -> unit -> unit t

  type mutex

  (** Create a recursive mutex that can be locked recursively by the same
    * thread; i.e., unlike a regular mutex,
    * [with_lock m (fun () -> ... with_lock m (fun () -> ... ))]
    * will not block. *)
  val create_recursive_mutex : unit -> mutex

  (* [with_lock m f] blocks until the [m] mutex can be locked, runs [f ()] and
   * unlocks the mutex (also if [f ()] raises an exception) *)
  val with_lock : mutex -> (unit -> 'a t) -> 'a t
end

(** Identity concurrency monad. Note that [Id.mutex] is a dummy type that
  * doesn't actually work like a mutex (i.e., [Id.with_lock m f] is equivalent
  * to [f ()]. This is so because n ocaml-sqlexpr's context [Sqlite] handles
  * can only be used from the thread where they were created, so there's no
  * need for mutual exclusion because trying to use the same handle from
  * different threads would be an error anyway. *)
module Id : THREAD with type 'a t = 'a

(** Lwt concurrency monad. *)
module Lwt : THREAD with type 'a t = 'a Lwt.t