package irmin
- Overview
- No Docs
You can search for identifiers within the package.
in-package search v0.2.0
Irmin, a distributed database that follows the same design principles as Git
Install
Dune Dependency
Authors
Maintainers
Sources
irmin-3.9.0.tbz
sha256=8e073abe1b5ffb5b6d58c32606c9d7dabc32c53501756be80a92ed4777ad51a0
sha512=70769a8d36520626fecd6f68e5f3abe6a0d67a65af915312206cc3f4da230df48512faee178aa6e899d3fb640b9340f6c92486185be5432a1a1a161c70386c99
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)"
>