1Stream(3)                        OCaml library                       Stream(3)
2
3
4

NAME

6       Stream - Streams and parsers.
7

Module

9       Module   Stream
10

Documentation

12       Module Stream
13        : sig end
14
15
16       Streams and parsers.
17
18
19
20
21
22       type 'a t
23
24
25       The type of streams holding values of type 'a .
26
27
28
29       exception Failure
30
31
32       Raised  by parsers when none of the first components of the stream pat‐
33       terns is accepted.
34
35
36
37       exception Error of string
38
39
40       Raised by parsers when the first component of a stream pattern  is  ac‐
41       cepted, but one of the following components is rejected.
42
43
44
45
46   Stream builders
47       val from : (int -> 'a option) -> 'a t
48
49
50       Stream.from f returns a stream built from the function f .  To create a
51       new stream element, the function f is called with  the  current  stream
52       count.  The user function f must return either Some <value> for a value
53       or None to specify the end of the stream.
54
55       Do note that the indices passed to f may not start at 0 in the  general
56       case.  For  example, [< '0; '1; Stream.from f >] would call f the first
57       time with count 2 .
58
59
60
61       val of_list : 'a list -> 'a t
62
63       Return the stream holding the elements of the list in the same order.
64
65
66
67       val of_string : string -> char t
68
69       Return the stream of the characters of the string parameter.
70
71
72
73       val of_bytes : bytes -> char t
74
75       Return the stream of the characters of the bytes parameter.
76
77
78       Since 4.02.0
79
80
81
82       val of_channel : in_channel -> char t
83
84       Return the stream of the characters read from the input channel.
85
86
87
88
89   Stream iterator
90       val iter : ('a -> unit) -> 'a t -> unit
91
92
93       Stream.iter f s scans the whole stream s, applying function f  in  turn
94       to each stream element encountered.
95
96
97
98
99   Predefined parsers
100       val next : 'a t -> 'a
101
102       Return the first element of the stream and remove it from the stream.
103
104
105       Raises Stream.Failure if the stream is empty.
106
107
108
109       val empty : 'a t -> unit
110
111       Return () if the stream is empty, else raise Stream.Failure .
112
113
114
115
116   Useful functions
117       val peek : 'a t -> 'a option
118
119       Return Some of "the first element" of the stream, or None if the stream
120       is empty.
121
122
123
124       val junk : 'a t -> unit
125
126       Remove the first element of the stream, possibly unfreezing it before.
127
128
129
130       val count : 'a t -> int
131
132       Return the current count of the stream elements, i.e. the number of the
133       stream elements discarded.
134
135
136
137       val npeek : int -> 'a t -> 'a list
138
139
140       npeek  n returns the list of the n first elements of the stream, or all
141       its remaining elements if less than n elements are available.
142
143
144
145
146
147OCamldoc                          2023-01-23                         Stream(3)
Impressum