Legend:
Library
Module
Module type
Parameter
Class
Class type
Library
Module
Module type
Parameter
Class
Class type
exception Read_error of read_error
val pp_read_error : Format.formatter -> read_error -> unit
val read_error_encoding : read_error t
val pp_write_error : Format.formatter -> write_error -> unit
val write_error_encoding : write_error t
exception Write_error of write_error
val length : 'a Encoding.t -> 'a -> int
Compute the expected length of the binary representation of a value
val fixed_length : 'a Encoding.t -> int option
Returns the size of the binary representation that the given encoding might produce, only when this size does not depends of the value itself.
E.g., fixed_length (tup2 int64 (Fixed.string 2))
is Some _
E.g., fixed_length (result int64 (Fixed.string 2))
is None
E.g., fixed_length (list (tup2 int64 (Fixed.string 2)))
is None
val maximum_length : 'a Encoding.t -> int option
Returns the maximum size of the binary representation that the given encoding might produce, only when this maximum size does not depends of the value itself.
E.g., maximum_length (tup2 int64 (Fixed.string 2))
is Some _
E.g., maximum_length (result int64 (Fixed.string 2))
is Some _
E.g., maximum_length (list (tup2 int64 (Fixed.string 2)))
is None
Note that the function assumes that recursive encodings (build using mu
) are used for recursive data types. As a result, maximum_length
will return None
if given a recursive encoding.
If there are static guarantees about the maximum size of the representation for values of a given type, you can wrap your encoding in check_size
. This will cause maximum_length
to return Some _
.
val read :
'a Encoding.t ->
string ->
int ->
int ->
(int * 'a, read_error) result
read enc buf ofs len
tries to reconstruct a value from the bytes in buf
starting at offset ofs
and reading at most len
bytes. This function also returns the offset of the first unread bytes in the buf
.
val read_opt : 'a Encoding.t -> string -> int -> int -> (int * 'a) option
val read_exn : 'a Encoding.t -> string -> int -> int -> int * 'a
type 'ret status =
| Await of Bytes.t -> 'ret status
Partially decoded value.
*)| Error of read_error
Failure. The stream is garbled and it should be dropped.
*)Return type for the function read_stream
.
val read_stream :
?init:Data_encoding__.Binary_stream.t ->
'a Encoding.t ->
'a status
Streamed equivalent of read
. This variant cannot be called on variable-size encodings.
The internal state that writers handle. It is presented explicitely as an abstract type so that you must use the constructor to obtain it. The constructor (make_writer_state
) performs basic bound checks.
val make_writer_state :
bytes ->
offset:int ->
allowed_bytes:int ->
writer_state option
make_writer_state buffer ~offset ~allowed_bytes
is None
if allowed_bytes < 0
, None
if allowed_bytes > length buffer - offset
, Some _
otherwise.
val write : 'a Encoding.t -> 'a -> writer_state -> (int, write_error) result
write enc v state
where Some state
is make_writer_state buffer ~offset ~allowed_bytes
writes the binary enc
representation of v
onto buffer
starting at offset
. The function will fail (returning Error _
) if the encoding would use more than allowed_bytes
.
The function returns the offset of first unwritten bytes, or returns Error _
in case of failure. In the latter case, some data might have been written on the buffer.
val write_opt : 'a Encoding.t -> 'a -> writer_state -> int option
val write_exn : 'a Encoding.t -> 'a -> writer_state -> int
val of_bytes : 'a Encoding.t -> Bytes.t -> ('a, read_error) result
of_bytes enc buf
is equivalent to read enc buf 0 (length buf)
. The function fails if the buffer is not fully read.
val of_bytes_opt : 'a Encoding.t -> Bytes.t -> 'a option
val of_bytes_exn : 'a Encoding.t -> Bytes.t -> 'a
of_bytes_exn enc buf
is equivalent to of_bytes
, except
val of_string : 'a Encoding.t -> string -> ('a, read_error) result
of_string enc buf
is like of_bytes enc buf
but it reads bytes from a string.
val of_string_opt : 'a Encoding.t -> string -> 'a option
val of_string_exn : 'a Encoding.t -> string -> 'a
val to_bytes :
?buffer_size:int ->
'a Encoding.t ->
'a ->
(Bytes.t, write_error) result
to_bytes enc v
is the equivalent of write env buf 0 len
where buf
is a newly allocated buffer. The parameter buffer_size
controls the initial size of buf
.
val to_bytes_opt : ?buffer_size:int -> 'a Encoding.t -> 'a -> Bytes.t option
val to_bytes_exn : ?buffer_size:int -> 'a Encoding.t -> 'a -> Bytes.t
to_bytes_exn enc v
is equivalent to to_bytes enc v
, except
val to_string :
?buffer_size:int ->
'a Encoding.t ->
'a ->
(string, write_error) result
to_string enc v
is like to_bytes
but it returns a string.
Note: to_string enc v
is always equal to Bytes.to_string (to_bytes enc v)
but more efficient.
val to_string_opt : ?buffer_size:int -> 'a Encoding.t -> 'a -> string option
val to_string_exn : ?buffer_size:int -> 'a Encoding.t -> 'a -> string
val describe : 'a Encoding.t -> Binary_schema.t