package octez-internal-libs
A package that contains some libraries used by the Octez suite
Install
Dune Dependency
Authors
Maintainers
Sources
tezos-octez-v20.1.tag.bz2
sha256=ddfb5076eeb0b32ac21c1eed44e8fc86a6743ef18ab23fff02d36e365bb73d61
sha512=d22a827df5146e0aa274df48bc2150b098177ff7e5eab52c6109e867eb0a1f0ec63e6bfbb0e3645a6c2112de3877c91a17df32ccbff301891ce4ba630c997a65
doc/src/octez-internal-libs.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)"
>