package irmin-pack
Irmin backend which stores values in a pack file
Install
Dune Dependency
Authors
Maintainers
Sources
irmin-3.1.0.tbz
sha256=d84fa343a841f663969ed6b08e5fc1b704d3ab7974858aa29471fe291a6a2f86
sha512=ab5eb4bd08ab69b97c8b9a72181c5b59d3d515e4ba63550d8a4551ec8ea72cd2d3b302fe0812379553e52891f81a9ae5d4d668382155d9c6c6eb75844a48477e
doc/src/irmin-pack/indexable.ml.html
Source file indexable.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
(* * 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. *) include Indexable_intf open! Import (* FIXME: remove code duplication with irmin/indexable *) module Closeable (S : S) = struct type 'a t = { closed : bool ref; t : 'a S.t } type key = S.key type hash = S.hash type value = S.value module Key = S.Key let check_not_closed t = if !(t.closed) then raise Irmin.Closed let mem t k = check_not_closed t; S.mem t.t k let find t k = check_not_closed t; S.find t.t k let index t h = check_not_closed t; S.index t.t h let index_direct t h = check_not_closed t; S.index_direct t.t h let add t v = check_not_closed t; S.add t.t v let unsafe_add t k v = check_not_closed t; S.unsafe_add t.t k v let batch t f = check_not_closed t; S.batch t.t (fun w -> f { t = w; closed = t.closed }) let close t = if !(t.closed) then Lwt.return_unit else ( t.closed := true; S.close t.t) let unsafe_append ~ensure_unique ~overcommit t k v = check_not_closed t; S.unsafe_append ~ensure_unique ~overcommit t.t k v let unsafe_mem t k = check_not_closed t; S.unsafe_mem t.t k let unsafe_find ~check_integrity t k = check_not_closed t; S.unsafe_find ~check_integrity t.t k let clear t = check_not_closed t; S.clear t.t let make_closeable t = { closed = ref false; t } let get_open_exn t = check_not_closed t; t.t end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>