package tezos-protocol-013-PtJakart
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
sha256=43723d096307603703a1a89ed1b2eb202b365f5e7824b96b0cbf813b343a6cf7
    
    
  sha512=b2a637f2e965000d3d49ad85277ca24d6cb07a1a7cf2bc69d296d8b03ad78c3eaa8e21e94b9162e62c2e11649cd03bc845b2a3dafe623b91065df69d47dc8e4f
    
    
  doc/tezos-protocol-013-PtJakart.raw/Tezos_raw_protocol_013_PtJakart/Indexable/index.html
Module Tezos_raw_protocol_013_PtJakart.IndexableSource
In transaction rollups, some values can be replaced by indexes in the messages sent from the layer-1 to the layer-2.
This module provides various type-safe helpers to manipulate these particular values.
type (_, 'a) t = private - | Value : 'a -> (value_only, 'a) t
- | Hidden_value : 'a -> (unknown, 'a) t
- | Index : int32 -> (index_only, 'a) t
- | Hidden_index : int32 -> (unknown, 'a) t
An indexable value is a value which can be replaced by an integer. The first type parameter determines whether or not this replacement has happened already.
The type of indexable values identified as not being indexes.
The type of indexable values identified as being indexes.
value v wraps v into an indexable value identified as not being an index.
from_value v wraps v into an indexable value, but forget about the nature of the content of the result.
index i wraps i into an indexable value identified as being an index.
Returns the error Index_cannot_be_negative iff i <= 0l.
val from_index : 
  int32 ->
  'a either Tezos_protocol_environment_013_PtJakart.Error_monad.tzresultfrom_index i wraps i into an indexable value, but forget about the nature of the content of the result.
Returns the error Index_cannot_be_negative iff i <= 0l.
index_exn i wraps i into an indexable value identified as being an index.
from_index_exn i wraps i into an indexable value, but forget about the nature of the content of the result.
val compact : 
  'a Tezos_protocol_environment_013_PtJakart.Data_encoding.t ->
  (unknown, 'a) t
    Tezos_protocol_environment_013_PtJakart.Data_encoding.Compact.tcompact val_encoding is a combinator to derive a compact encoding for an indexable value of type 'a from an encoding for 'a. It uses two bits in the shared tag. 00 is used for indexes fitting in one byte, 01 for indexes fitting in two bytes, 10 for indexes fitting in four bytes, and 11 for the values of type 'a.
val pp : 
  (Tezos_protocol_environment_013_PtJakart.Format.formatter -> 'a -> unit) ->
  Tezos_protocol_environment_013_PtJakart.Format.formatter ->
  ('state, 'a) t ->
  unitval destruct : 
  ('state, 'a) t ->
  ('a index, 'a) Tezos_protocol_environment_013_PtJakart.Either.tdestruct x returns either the index or the (unwrapped) value contained in x.
Note: If you want to manipulate a value of type 'a value, you can use value.
forget x returns an indexable value whose kind of contents has been forgotten.
val is_value_e : 
  error:'trace ->
  ('state, 'a) t ->
  ('a, 'trace) Tezos_protocol_environment_013_PtJakart.Pervasives.resultis_value_e err x unwraps and returns the value behind x, and throws an err if x is an index.
val in_memory_size : 
  ('a -> Cache_memory_helpers.sint) ->
  ('state, 'a) t ->
  Cache_memory_helpers.sintin_memory_size a returns the number of bytes allocated in RAM for a.
size a returns the number of bytes allocated in an inbox to store a.
compare f x y is a total order on indexable values, which proceeds as follows.
- If both xandyare a value, then usefto compare them.
- If both xandyare indexes, then uses theInt32.comparefunction to compare them.
- Finally, if xandyhave not the same kind, the logic is that indexes are smaller than values.
Note: This can be dangerous, as you may end up comparing two things that are equivalent (a value and its index) but declare they are not equal.
compare_values f x y compares the value x and y using f, and relies on the type system of OCaml to ensure that x and y are indeed both values.
compare_indexes x y compares the indexes x and y, and relies on the type system of OCaml to ensure that x and y are indeed both indexes.