package irmin-pack
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>
Irmin backend which stores values in a pack file
Install
dune-project
Dependency
Authors
Maintainers
Sources
irmin-3.5.2.tbz
sha256=2a1e6a7577e498fbfeb678d666da210dc48d1344637e8ecb653e1dd88c640b5f
sha512=3fb6f49a1af2f8bab1df5b6f5affaaa09f09fe892a08eb2d9de58138e56646d4a6797f3c087b22875e36e3411218ab2435fe5437ac78f323dd661932af021fad
doc/src/irmin-pack.unix/chunked_suffix_intf.ml.html
Source file chunked_suffix_intf.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 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137
(* * Copyright (c) 2022-2022 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 module type S = sig (** Abstraction for a chunked suffix. It is functionally equivalent to {!Append_only_file} but with a chunked implementation that is parameterized by - [start_idx] for {!create_rw} to know the starting file name, and - [start_idx] and [chunk_num] for the open functions to know the starting file name and how many files there are. *) module Io : Io.S module Errs : Io_errors.S module Ao : Append_only_file.S type t type create_error = Io.create_error type open_error = [ Io.open_error | `Closed | `Invalid_argument | `Inconsistent_store | `Read_out_of_bounds ] type add_new_error = [ open_error | Io.close_error | `Pending_flush | `File_exists of string | `Multiple_empty_chunks ] val create_rw : root:string -> start_idx:int -> overwrite:bool -> auto_flush_threshold:int -> auto_flush_procedure:Ao.auto_flush_procedure -> (t, [> create_error ]) result val open_rw : root:string -> appendable_chunk_poff:int63 -> start_idx:int -> chunk_num:int -> dead_header_size:int -> auto_flush_threshold:int -> auto_flush_procedure:Ao.auto_flush_procedure -> (t, [> open_error ]) result val open_ro : root:string -> appendable_chunk_poff:int63 -> dead_header_size:int -> start_idx:int -> chunk_num:int -> (t, [> open_error ]) result val add_chunk : auto_flush_threshold:int -> auto_flush_procedure:Ao.auto_flush_procedure -> t -> (unit, [> add_new_error ]) result val start_idx : t -> int val chunk_num : t -> int val close : t -> (unit, [> Io.close_error | `Pending_flush ]) result val empty_buffer : t -> bool val flush : t -> (unit, [> Io.write_error ]) result val fsync : t -> (unit, [> Io.write_error ]) result val appendable_chunk_poff : t -> int63 (** [appendable_chunk_poff t] is the number of bytes of the chunk file that is currently appendable. It does not perform IO. {3 RW mode} It also counts the bytes not flushed yet. {3 RO mode} This information originates from the latest reload of the control file. Calling [refresh_appendable_chunk_poff t] updates [appendable_chunk_poff]. *) val refresh_appendable_chunk_poff : t -> int63 -> (unit, [> `Rw_not_allowed ]) result (** Ingest the new end offset of the appendable chunk file. Typically happens in RO mode when the control file has been re-read. {3 RW mode} Always returns [Error `Rw_not_allowed]. *) val end_soff : t -> int63 (** [end_soff t] is the end offset for the chunked suffix. The valid range of offsets is 0 <= off < end_soff. Therefore, [end_soff] also represents the length of the chunked suffix. *) val read_exn : t -> off:int63 -> len:int -> bytes -> unit val append_exn : t -> string -> unit val readonly : t -> bool val auto_flush_threshold : t -> int option val fold_chunks : (acc:'a -> idx:int -> start_suffix_off:int63 -> end_suffix_off:int63 -> is_appendable:bool -> 'a) -> 'a -> t -> 'a end module type Sigs = sig module type S = S module Make (Io : Io.S) (Errs : Io_errors.S with module Io = Io) : S with module Io = Io and module Errs = Errs end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>