Bigstring helpers for shexp libraries
val create : int ‑> tval length : t ‑> intval blit_string_t : src:string ‑> src_pos:int ‑> dst:t ‑> dst_pos:int ‑> len:int ‑> unitval blit_t_bytes : src:t ‑> src_pos:int ‑> dst:Bytes.t ‑> dst_pos:int ‑> len:int ‑> unitval sub_string : t ‑> pos:int ‑> len:int ‑> stringval index : t ‑> pos:int ‑> len:int ‑> char:char ‑> int optionval rindex : t ‑> pos:int ‑> len:int ‑> char:char ‑> int optionval pos_len_ok : pos:int ‑> len:int ‑> length:int ‑> boolEfficiently checks that the range denoted by (pos, len) is in the range
0..length. length is assumed to be >= 0.
val check_pos_len_exn : pos:int ‑> len:int ‑> length:int ‑> unitRaises if (pos, len) denotes a range outside of 0..length.
val with_temporary : size:int ‑> f:(t ‑> 'a) ‑> 'aAllocate a bigstring and pass it to f. The memory allocated for the bigstring is
released as soon as f returns. As such, the bigstring shouldn't be used after f
returns.
This is more efficient than waiting on the garbage collector to release the external memory.
val fold_temporary : size:int ‑> init:'a ‑> f:(t ‑> 'a ‑> ('a, 'b) fold_temporary_result) ‑> 'bSame as with_temporary, but allow to resize the bigstring if needed.
If f returns Resize { new_size; state }, the bigstring will be resized to the
given new size and f will be called with the new bigstring and state. The contents
of the bigstring up to the min of the old and new sizes is preserved.