Module combine::stream [−][src]
Traits and implementations of arbitrary data streams.
Streams are similar to the Iterator
trait in that they represent some sequential set of items
which can be retrieved one by one. Where Stream
s differ is that they are allowed to return
errors instead of just None
and if they implement the RangeStreamOnce
trait they are also
capable of returning multiple items at the same time, usually in the form of a slice.
In addition to he functionality above, a proper Stream
usable by a Parser
must also have a
position (marked by the Positioned
trait) and must also be resetable (marked by the
Resetable
trait). The former is used to ensure that errors at different points in the stream
aren’t combined and the latter is used in parsers such as or
to try multiple alternative
parses.
Modules
buffered | |
easy | Stream wrapper which provides an informative and easy to use error type. |
state | Stateful stream wrappers. |
Structs
IteratorStream | Wrapper around iterators which allows them to be treated as a stream.
Returned by |
PartialStream | Stream type which indicates that the stream is partial if end of input is reached |
PointerOffset | Newtype around a pointer offset into a slice stream ( |
ReadStream | |
SliceStream | Newtype for constructing a stream from a slice where the items in the slice are not copyable. |
Traits
FullRangeStream | A |
Positioned | A type which has a position. |
Range | Trait representing a range of elements. |
RangeStream | A |
RangeStreamOnce | A |
Resetable | |
Stream | A stream of tokens which can be duplicated |
StreamOnce |
|
Functions
decode | Decodes |
uncons | |
uncons_range | |
uncons_while | Removes items from the input while |
uncons_while1 | Takes items from stream, testing each one with |
Type Definitions
StreamErrorFor | Convenience alias over the |