package irmin-pack
- Overview
- No Docs
You can search for identifiers within the package.
in-package search v0.2.0
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
sha256=6aa5ba4c6a0233747d4bd3ab396f2b3a33bb80f9d8ed4a178c83a035033c0e52
    
    
  sha512=8a5506a57e8569a11c883ca25b3c60ae7a9a03c2da111668193d7b4296434c43f1a310e78f189e4b38c234da790259d2961c6a0ae481282c18bb97f618fccfb6
    
    
  doc/irmin-pack.unix/Irmin_pack_unix/Lower/Make/index.html
Module Lower.MakeSource
Parameters
module Errs : Io_errors.S with module Io = IoSignature
module Io = Iomodule Errs = Errstype add_error = [ - | open_error
- | `Ro_not_allowed
- | `Multiple_empty_volumes
- | `File_exists of string
- | `Invalid_parent_directory
 ]v ~readonly ~volume_num lower_root loads all volumes located in the directory lower_root.
volume_num is the number of volumes that are expected in lower_root. 0 is valid for an empty lower.
Error `Volume_missing path is returned if an expected volume is not on disk, with the path to first volume that is missing. This can happen if volume_num is larger than the number of volumes on disk, or if one of the volume directories has been renamed accidentally.
If readonly is false, no write operations are allowed.
reload ~volume_num t reloads volumes located in the root directory of t, using volume_num as the expected number of volumes.
close t closes all resources opened by t.
add_volume t adds a new empty volume to t.
If there is already an empty volume, Error `Multiple_empty_volumes is returned. Only one empty volume is allowed.
If t is read-only, Error `Ro_not_allowed is returned.
find_volume ~off t returns the Volume that contains off.
val read_exn : 
  off:Optint.Int63.t ->
  len:int ->
  ?volume:volume_identifier ->
  t ->
  bytes ->
  volume_identifierread_exn ~off ~len ~volume t b will read len bytes from a global off located in the volume with identifier volume. The volume identifier of the volume where the read occurs is returned.
If volume is not provided, find_volume will be used to attempt to locate the correct volume for the read.
set_readonly t flag changes the writing permission of the lower layer (where true is read only). This should only be called by the GC worker to temporarily allow RW before calling archive_seq_exn.
val archive_seq_exn : 
  upper_root:string ->
  generation:int ->
  to_archive:(Optint.Int63.t * string Irmin.Export_for_backends.Seq.t) list ->
  t ->
  volume_identifierarchive_seq ~upper_root ~generation ~to_archive t is called by the GC worker during the creation of the new generation to archive to_archive in the lower layer and returns the identifier of the volume where data was appended.
It is the only write operation allowed on the lower layer, and it makes no observable change as the control file is left untouched : instead new changes are written to volume.gen.control, which is swapped during GC finalization.
val read_range_exn : 
  off:Optint.Int63.t ->
  min_len:int ->
  max_len:int ->
  ?volume:volume_identifier ->
  t ->
  bytes ->
  int * volume_identifierSame as read_exn but will read at least min_len bytes and at most max_len. Returns the read length and the volume identifier from which the data was fetched.
val create_from : 
  src:string ->
  dead_header_size:int ->
  size:Optint.Int63.t ->
  string ->
  (unit, [> create_error ]) resultcreate_from ~src ~dead_header_size ~size lower_root initializes the first lower volume in the directory lower_root by moving the suffix file src with end offset size.
val swap : 
  volume:volume_identifier ->
  generation:int ->
  volume_num:int ->
  t ->
  (unit, [> `Volume_not_found of string | `Sys_error of string | open_error ])
    resultswap ~volume ~generation ~volume_num t will rename a new volume control file in volume for generation of GC and then reload the lower with volume_num volumes.