This file is indexed.

/usr/lib/ocaml/lwt/lwt_pool.mli is in liblwt-ocaml-dev 2.7.1-4build1.

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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
(* Lwt
 * http://www.ocsigen.org
 * Copyright (C) 2008 Jérôme Vouillon
 *               2012 Jérémie Dimino
 * Laboratoire PPS - CNRS Université Paris Diderot
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as published by
 * the Free Software Foundation, with linking exceptions;
 * either version 2.1 of the License, or (at your option) any later version.
 * See COPYING file for details.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
 *)

(** External resource pools. *)

(** For example, instead of creating a new database connection each time you
    need one, keep a pool of opened connections and reuse ones that are free.
    The pool also provides a limit on the number of connections that can
    simultaneously be open.

    Note that pools are not for keeping Lwt threads. Lwt threads are very cheap
    to create and are pure. It is neither desirable nor possible to reuse them.
    If you want to have a pool of {e system} threads, consider module
    [Lwt_preemptive]. *)

type 'a t
  (** Pools containing values of type ['a]. *)

val create :
  int ->
  ?check : ('a -> (bool -> unit) -> unit) ->
  ?validate : ('a -> bool Lwt.t) ->
  (unit -> 'a Lwt.t) -> 'a t
  (** [create n ?check ?validate f] creates a new pool with at most
      [n] elements. [f] is the function to use to create a new element
      Elements are created on demand.

      An element of the pool is validated by the optional [validate]
      function before its {!use}. Invalid elements are re-created.

      The optional function [check] is called after a [use] of an
      element failed. It must call its argument exactly once with
      [true] if the element is still valid and [false] otherwise. *)

val use : 'a t -> ('a -> 'b Lwt.t) -> 'b Lwt.t
  (** [use p f] takes one free element of the pool [p] and gives it to
      the function [f]. The element is put back into the pool after the
      thread created by [f] completes. *)