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.10.0.tbz
sha256=92a9de7a0a2a35c2feba0c35a806b1f0df24c1c0d15164eebf3f919296d26715
sha512=0203ec5117a851ad5afeb2f9091659b4e142e231b6b945caab93f4d7beb23397c8ac43f7056e91d18f4bff0be1062f6ae966d221f877c229328c0cbbf29fd9f0
doc/src/irmin-pack.unix/append_only_file_intf.ml.html
Source file append_only_file_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 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167
(* * 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 irmin-pack's append only files (i.e. suffix and dict). It is parameterized with [Io], a file system abstraction (e.g. unix, mirage, eio_linux). It comprises a persistent file, an append buffer and take care of automatically shifting offsets to deal with legacy file headers. *) module Io : Io.S module Errs : Io_errors.S type t val create_rw : path:string -> overwrite:bool -> (t, [> Io.create_error ]) result (** Create a rw instance of [t] by creating the file at [path]. *) val open_rw : path:string -> end_poff:int63 -> dead_header_size:int -> ( t, [> Io.open_error | `Closed | `Invalid_argument | `Read_out_of_bounds | `Inconsistent_store ] ) result (** Create a rw instance of [t] by opening an existing file at [path]. {3 End Offset} The file has an end offset at which new data will be saved. While this information could be computed by looking at the size of the file, we prefer storing that information elsewhere (i.e. in the control file). This is why [open_rw] and [open_ro] take an [end_poff] parameter, and also why [refresh_end_poff] exists. The abstractions above [Append_only_file] are responsible for reading/writing the offsets from/to the control file. {3 [dead_header_size]} Designates a small area at the beginning of the file that should be ignored. The offsets start after that area. The actual persisted size of a file is [end_poff + dead_header_size]. This concept exists in order to keep supporting [`V1] and [`V2] pack stores with [`V3]. *) val open_ro : path:string -> end_poff:int63 -> dead_header_size:int -> ( t, [> Io.open_error | `Closed | `Inconsistent_store | `Invalid_argument | `Read_out_of_bounds ] ) result (** Create a ro instance of [t] by opening an existing file at [path] *) val close : t -> (unit, [> Io.close_error | `Pending_flush ]) result (** Close the underlying file. The internal buffer is expected to be in a flushed state when [close] is called. Otherwise, an error is returned. *) val end_poff : t -> int63 (** [end_poff t] is the number of bytes of the file. That function doesn't 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_end_poff t] updates [end_poff]. *) val read_to_string : t -> off:int63 -> len:int -> (string, [> Io.read_error ]) result val read_exn : t -> off:int63 -> len:int -> bytes -> unit (** [read_exn t ~off ~len b] puts the [len] bytes of [t] at [off] to [b]. [read_to_string] should always be favored over [read_exn], except when performences matter. It is not possible to read from an offset further than [end_poff t]. Raises [Io.Read_error] and [Errors.Pack_error `Read_out_of_bounds]. {3 RW mode} Attempting to read from the append buffer results in an [`Read_out_of_bounds] error. This feature could easily be implemented in the future if ever needed. *) val append_exn : t -> string -> unit (** [append_exn t ~off b] writes [b] to the end of [t]. Might trigger an auto flush. Grows [end_poff], but the parent abstraction is expected to persist this somewhere (e.g. in the control file). Post-condition: [end_poff t - end_poff (old t) = String.length b]. Raises [Io.Write_error] {3 RW mode} Always raises [Errors.RO_not_allowed] *) val flush : t -> (unit, [> Io.write_error ]) result (** Flush the append buffer. Does not call [fsync]. {3 RO mode} Always returns [Error `Ro_not_allowed]. *) val fsync : t -> (unit, [> Io.write_error ]) result (** Tell the os to fush its internal buffers. Does not call [flush]. {3 RO mode} Always returns [Error `Ro_not_allowed]. *) val refresh_end_poff : t -> int63 -> (unit, [> `Rw_not_allowed ]) result (** Ingest the new end offset of the file. Typically happens in RO mode when the control file has been re-read. {3 RW mode} Always returns [Error `Rw_not_allowed]. *) val readonly : t -> bool val empty_buffer : t -> bool val path : t -> string 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)"
>