Module Bigstring_marshal

module Bigstring_marshal: sig .. end
Utility functions for marshalling to and from bigstring
Author(s): Markus Mottl <mmottl@janestreet.com>


Marshalling to/from bigstrings

val marshal_blit : ?flags:Marshal.extern_flags list ->
'a -> ?pos:int -> ?len:int -> Bigstring.t -> int
marshal_blit ?flags v ?pos ?len buf marshals value v to bigstring buf starting at position pos and at most len bytes.
Raises
flags : default = []
pos : default = 0
len : default = length buf - pos
val marshal : ?flags:Marshal.extern_flags list -> 'a -> Bigstring.t
marshal ?flags v marshals value v to a bigstring using marshalling flags flags. This function may need two times more memory than marshal_blit.
flags : default = []
val marshal_data_size : ?pos:int -> Bigstring.t -> int
marshal_data_size ?pos buf
Raises Invalid_argument if the position is out of bounds considering a valid marshal header.
Returns the length of marshalled data in bigstring buf starting at position pos.
pos : default = 0
val unmarshal : ?pos:int -> Bigstring.t -> 'a
unmarshal ?pos buf unmarshals data contained in buf starting at position pos.
Raises Invalid_argument if the position is out of bounds, or if there is not enough data for unmarshalling.
pos : default = 0
val unmarshal_next : ?pos:int -> Bigstring.t -> 'a * int
unmarshal_next ?pos buf unmarshals data contained in buf starting at position pos.
Raises Invalid_argument if the position is out of bounds, or if there is not enough data for unmarshalling.
Returns (v, next_pos), where v is the unmarshalled value, and next_pos designates the start of the byte following the unmarshalled data.
pos : default = 0
val skip : ?pos:int -> Bigstring.t -> int
skip ?pos buf skips the marshalled data starting at position pos.
Raises Invalid_argument if the position is out of bounds, or if there is not enough data for unmarshalling.
Returns the start of the byte following the unmarshalled data.
pos : default = 0