[−][src]Module combine::stream
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 Streams 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 |