Legend:
Page
Library
Module
Module type
Parameter
Class
Class type
Source
Source file buffer_intf.ml
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182open!ImportmoduletypeS=sig(** The abstract type of buffers. *)typet[@@deriving_inlinesexp_of]valsexp_of_t:t->Sexplib0.Sexp.t[@@@end](** [create 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. *)valcreate:int->t(** Return a copy of the current contents of the buffer. The buffer itself is
unchanged. *)valcontents:t->stringvalcontents_bytes:t->bytes(** [blit ~src ~src_pos ~dst ~dst_pos ~len] copies [len] characters from the current
contents of the buffer [src], starting at offset [src_pos] to bytes [dst], starting
at character [dst_pos].
Raises [Invalid_argument] if [src_pos] and [len] do not designate a valid substring
of [src], or if [dst_pos] and [len] do not designate a valid substring of [dst]. *)includeBlit.S_distinctwithtypesrc:=twithtypedst:=bytesmoduleTo_string:Blit.S_to_stringwithtypet:=t(** Gets the (zero-based) n-th character of the buffer. Raises [Invalid_argument] if
index out of bounds. *)valnth:t->int->char(** Returns the number of characters currently contained in the buffer. *)vallength:t->int(** Empties the buffer. *)valclear:t->unit(** Empties 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. *)valreset:t->unit(** [add_char b c] appends the character [c] at the end of the buffer [b]. *)valadd_char:t->char->unit(** [add_string b s] appends the string [s] at the end of the buffer [b]. *)valadd_string:t->string->unit(** [add_substring b s pos len] takes [len] characters from offset [pos] in string [s]
and appends them at the end of the buffer [b]. *)valadd_substring:t->string->pos:int->len:int->unit(** [add_bytes b s] appends the bytes [s] at the end of the buffer [b]. *)valadd_bytes:t->bytes->unit(** [add_subbytes b s pos len] takes [len] characters from offset [pos] in bytes [s]
and appends them at the end of the buffer [b]. *)valadd_subbytes:t->bytes->pos:int->len:int->unit(** [add_buffer b1 b2] appends the current contents of buffer [b2] at the end of buffer
[b1]. [b2] is not modified. *)valadd_buffer:t->t->unitendmoduletypeBuffer=sigmoduletypeS=S(** Buffers using strings as underlying storage medium: *)includeSwithtypet=Stdlib.Buffer.t(** @open *)end