package orsetto
Install
Dune Dependency
Authors
Maintainers
Sources
sha256=151ca6df499bd3de7aa89a4e1627411fbee24c4dea6e0e71ce21f06f181ee654
md5=00393728b481c2bf15919a8202732335
doc/orsetto.cbor/Cbor_decode/Int_map/index.html
Module Cbor_decode.Int_map
A record module with integer indexes.
type field =
| Required : {
nym : 'a Cf_type.nym;
scan : 'a Annot.form t;
} -> field
(*A field of the named type is required.
*)| Optional : {
nym : 'a Cf_type.nym;
scan : 'a Annot.form t;
} -> field
(*A field of the named type is optional.
*)| Default : {
nym : 'a Cf_type.nym;
scan : 'a Annot.form t;
default : 'a;
} -> field
(*A field of the named type is optional with a default value.
*)
Field descriptor type. A schema contains a map of indexes to values of this type, which indicate whether the field is required or optional, along with a description of the type of the field value and a scanner for values of that type.
Use schema fields
to make a record schema for scanning records according to fields
. If ~ignore:(n, p)
is provided, then as many as n
unrecognized fields are scanned according to p
and their values are discarded.
val range : schema -> int * int
Use range schema
to get the minimum and maximum number of fields that can be processed by scanning with schema
.
Use scan schema
to scan a record according to schema
producing a pack value containing all the values in the record.
val unpack : pack -> int -> 'a Cf_type.nym -> 'a Annot.form
Use unpack pack index nym
to unpack from pack
the value for the field named by index
with the type nym
.
Note well: fields with Optional type in the schema are packed with the corresponding Cf_type.Option
type nym, and the unpacked value is either Some v
if the field is present in the scanned record, or None
if the field was not present.