package irmin-pack
Irmin backend which stores values in a pack file
Install
Dune Dependency
Authors
Maintainers
Sources
irmin-3.3.1.tbz
sha256=535254ca443858bfc9e540535977fed63e9206d4b78c5cac0239d1e6657b5c78
sha512=fa18557fcf808121a0495de707c6f7bff4a69197b310480816648adafd4a659b5673a1f5bbf4574f517b7d93253735ef7798b0c365d87afac60675007ef19b54
doc/src/irmin-pack/atomic_write.ml.html
Source file atomic_write.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 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94
(* * Copyright (c) 2018-2021 Tarides <contact@tarides.com> * * 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 include Atomic_write_intf module Value = struct module type S = Value module Of_hash (X : Irmin.Hash.S) = struct type t = X.t [@@deriving irmin ~of_bin_string] let null = match of_bin_string (String.make X.hash_size '\000') with | Ok x -> x | Error _ -> assert false end end (* FIXME: remove code duplication with irmin/atomic_write *) module Closeable (AW : S) = struct type t = { closed : bool ref; t : AW.t } type key = AW.key type value = AW.value let check_not_closed t = if !(t.closed) then raise Irmin.Closed let mem t k = check_not_closed t; AW.mem t.t k let find t k = check_not_closed t; AW.find t.t k let set t k v = check_not_closed t; AW.set t.t k v let test_and_set t k ~test ~set = check_not_closed t; AW.test_and_set t.t k ~test ~set let remove t k = check_not_closed t; AW.remove t.t k let list t = check_not_closed t; AW.list t.t type watch = AW.watch let watch t ?init f = check_not_closed t; AW.watch t.t ?init f let watch_key t k ?init f = check_not_closed t; AW.watch_key t.t k ?init f let unwatch t w = check_not_closed t; AW.unwatch t.t w let make_closeable t = { closed = ref false; t } let close t = if !(t.closed) then Lwt.return_unit else ( t.closed := true; AW.close t.t) let clear t = check_not_closed t; AW.clear t.t let flush t = check_not_closed t; AW.flush t.t end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>