package irmin
Irmin, a distributed database that follows the same design principles as Git
Install
Dune Dependency
Authors
Maintainers
Sources
irmin-2.6.1.tbz
sha256=7729777c336f716a064f3c698a25412efb2ce830bc0f3f9e5248d3caac66e4a6
sha512=15c8aae18bbc4dbb86708caf0fe41f621a41db38645d1a7e93fb9c1c5e3fea33c6dfbf0ffbed499b1482674b88dd5c847110dc54d9956c9c20dec3d9d4e5f145
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-2017 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)"
>