Module Caml.Stream
exceptionFailureRaised by parsers when none of the first components of the stream patterns is accepted.
exceptionError of stringRaised by parsers when the first component of a stream pattern is accepted, but one of the following components is rejected.
Stream builders
val from : (int -> 'a option) -> 'a tStream.from freturns a stream built from the functionf. To create a new stream element, the functionfis called with the current stream count. The user functionfmust return eitherSome <value>for a value orNoneto specify the end of the stream.Do note that the indices passed to
fmay not start at0in the general case. For example,[< '0; '1; Stream.from f >]would callfthe first time with count2.
val of_list : 'a list -> 'a tReturn the stream holding the elements of the list in the same order.
val of_string : string -> char tReturn the stream of the characters of the string parameter.
val of_bytes : bytes -> char tReturn the stream of the characters of the bytes parameter.
- since
- 4.02.0
val of_channel : Stdlib.in_channel -> char tReturn the stream of the characters read from the input channel.
Stream iterator
val iter : ('a -> unit) -> 'a t -> unitStream.iter f sscans the whole stream s, applying functionfin turn to each stream element encountered.
Predefined parsers
val next : 'a t -> 'aReturn the first element of the stream and remove it from the stream. Raise
Stream.Failure if the stream is empty.
val empty : 'a t -> unitReturn
()if the stream is empty, else raiseStream.Failure.
Useful functions
val peek : 'a t -> 'a optionReturn
Someof "the first element" of the stream, orNoneif the stream is empty.
val junk : 'a t -> unitRemove the first element of the stream, possibly unfreezing it before.
val count : 'a t -> intReturn the current count of the stream elements, i.e. the number of the stream elements discarded.
val npeek : int -> 'a t -> 'a listnpeek nreturns the list of thenfirst elements of the stream, or all its remaining elements if less thannelements are available.