package irmin
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>
Irmin, a distributed database that follows the same design principles as Git
Install
dune-project
Dependency
Authors
Maintainers
Sources
irmin-3.5.2.tbz
sha256=2a1e6a7577e498fbfeb678d666da210dc48d1344637e8ecb653e1dd88c640b5f
sha512=3fb6f49a1af2f8bab1df5b6f5affaaa09f09fe892a08eb2d9de58138e56646d4a6797f3c087b22875e36e3411218ab2435fe5437ac78f323dd661932af021fad
doc/src/irmin/lock.ml.html
Source file lock.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 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 58 59 60 61 62 63 64 65 66(* * Copyright (c) 2013-2022 Thomas Gazagnaire <thomas@gazagnaire.org> * * Permission to use, copy, modify, and distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice appear in all copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. *) open! Import module type S = sig type key type t val v : unit -> t val with_lock : t -> key -> (unit -> 'a Lwt.t) -> 'a Lwt.t val stats : t -> int end module Make (K : Type.S) = struct module K = struct type t = K.t let hash = Hashtbl.hash let equal = Type.(unstage (equal K.t)) end module KHashtbl = Hashtbl.Make (K) type key = K.t type t = { global : Lwt_mutex.t; locks : Lwt_mutex.t KHashtbl.t } let v () = { global = Lwt_mutex.create (); locks = KHashtbl.create 1024 } let stats t = KHashtbl.length t.locks let lock t key () = let lock = try KHashtbl.find t.locks key with Not_found -> let lock = Lwt_mutex.create () in KHashtbl.add t.locks key lock; lock in Lwt.return lock let unlock t key () = let () = if KHashtbl.mem t.locks key then let lock = KHashtbl.find t.locks key in if Lwt_mutex.is_empty lock then KHashtbl.remove t.locks key in Lwt.return_unit let with_lock t k fn = let* lock = Lwt_mutex.with_lock t.global (lock t k) in let* r = Lwt_mutex.with_lock lock fn in Lwt_mutex.with_lock t.global (unlock t k) >>= fun () -> Lwt.return r end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>