Extensible character buffers.
This module implements character buffers that automatically expand as necessary. It provides cumulative concatenation of strings in quasi-linear time (instead of quadratic time when strings are concatenated pairwise).
module type S = Base__.Buffer_intf.SBuffers using strings as underlying storage medium:
include S with type S.t = Caml.Buffer.tval create : int ‑> tcreate n returns a fresh buffer, initially empty. The n parameter is the
initial size of the internal storage medium that holds the buffer contents. That
storage is automatically reallocated when more than n characters are stored in the
buffer, but shrinks back to n characters when reset is called.
For best performance, n should be of the same order of magnitude as the number of
characters that are expected to be stored in the buffer (for instance, 80 for a
buffer that holds one output line). Nothing bad will happen if the buffer grows
beyond that limit, however. In doubt, take n = 16 for instance.
val contents : t ‑> stringReturn a copy of the current contents of the buffer. The buffer itself is unchanged.
val contents_bytes : t ‑> bytesval blit : (t, bytes) Base__.Blit_intf.blitval blito : (t, bytes) Base__.Blit_intf.blitoval unsafe_blit : (t, bytes) Base__.Blit_intf.blitval sub : (t, bytes) Base__.Blit_intf.subval subo : (t, bytes) Base__.Blit_intf.suboval nth : t ‑> int ‑> charGets the (zero-based) n-th character of the buffer. Raises Invalid_argument if
index out of bounds.
val reset : t ‑> unitEmpties the buffer and deallocates the internal storage holding the buffer contents,
replacing it with the initial internal storage of length n that was allocated by
create n. For long-lived buffers that may have grown a lot, reset allows faster
reclamation of the space used by the buffer.
val add_substring : t ‑> string ‑> pos:int ‑> len:int ‑> unitadd_substring b s pos len takes len characters from offset pos in string s
and appends them at the end of the buffer b.
val add_subbytes : t ‑> bytes ‑> pos:int ‑> len:int ‑> unitadd_subbytes b s pos len takes len characters from offset pos in bytes s
and appends them at the end of the buffer b.