Source file shims.ml

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
# 1 "caqti/lib-template/shims.5.1.ml"
(* Copyright (C) 2025  Petter A. Urkedal <paurkedal@gmail.com>
 *
 * This library 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, either version 3 of the License, or (at your
 * option) any later version, with the LGPL-3.0 Linking Exception.
 *
 * This library 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
 * and the LGPL-3.0 Linking Exception along with this library.  If not, see
 * <http://www.gnu.org/licenses/> and <https://spdx.org>, respectively.
 *)

module Type = struct
  type ('a, 'b) eq = ('a, 'b) Stdlib.Type.eq = Equal : ('a, 'a) eq
end

module Atomic = struct
  type 'a t = 'a Stdlib.Atomic.t
  let make = Stdlib.Atomic.make
  let fetch_and_add = Stdlib.Atomic.fetch_and_add
end

let memo_if_safe ?hashed ?weight ~cap f =
  let mutex = Stdlib.Mutex.create () in
  let f' = Lru.memo ?hashed ?weight ~cap f in
  fun x -> Stdlib.Mutex.protect mutex (fun () -> f' x)