Struct combine::stream::buffered::BufferedStream
source · pub struct BufferedStream<I>where
I: StreamOnce + Positioned,{ /* private fields */ }Expand description
Stream which buffers items from an instance of StreamOnce into a ring buffer.
Instances of StreamOnce which is not able to implement Resetable (such as ReadStream) may
use this as a way to implement Resetable and become a full Stream instance.
The drawback is that the buffer only stores a limited number of items which limits how many
tokens that can be reset and replayed. If a BufferedStream is reset past this limit an error
will be returned when uncons is next called.
NOTE: If this stream is used in conjunction with an error enhancing stream such as
easy::Stream (also via the easy_parser method) it is recommended that the BufferedStream
instance wraps the easy::Stream instance instead of the other way around.
// DO
BufferedStream::new(easy::Stream(..), ..)
// DON'T
easy::Stream(BufferedStream::new(.., ..))
parser.easy_parse(BufferedStream::new(..));Implementations§
source§impl<I> BufferedStream<I>where
I: StreamOnce + Positioned,
I::Position: Clone,
I::Item: Clone,
impl<I> BufferedStream<I>where I: StreamOnce + Positioned, I::Position: Clone, I::Item: Clone,
sourcepub fn new(iter: I, lookahead: usize) -> BufferedStream<I>
pub fn new(iter: I, lookahead: usize) -> BufferedStream<I>
Constructs a new BufferedStream from a StreamOnce instance with a lookahead
number of elements that can be stored in the buffer.
Trait Implementations§
source§impl<I> Debug for BufferedStream<I>where
I: StreamOnce + Positioned + Debug,
I::Item: Debug,
I::Position: Debug,
impl<I> Debug for BufferedStream<I>where I: StreamOnce + Positioned + Debug, I::Item: Debug, I::Position: Debug,
source§impl<I> PartialEq for BufferedStream<I>where
I: StreamOnce + Positioned + PartialEq,
I::Item: PartialEq,
I::Position: PartialEq,
impl<I> PartialEq for BufferedStream<I>where I: StreamOnce + Positioned + PartialEq, I::Item: PartialEq, I::Position: PartialEq,
source§fn eq(&self, other: &BufferedStream<I>) -> bool
fn eq(&self, other: &BufferedStream<I>) -> bool
self and other values to be equal, and is used
by ==.source§impl<I> Positioned for BufferedStream<I>where
I: StreamOnce + Positioned,
impl<I> Positioned for BufferedStream<I>where I: StreamOnce + Positioned,
source§impl<I> Resetable for BufferedStream<I>where
I: Positioned,
impl<I> Resetable for BufferedStream<I>where I: Positioned,
type Checkpoint = usize
fn checkpoint(&self) -> Self::Checkpoint
fn reset(&mut self, checkpoint: Self::Checkpoint)
source§impl<I> StreamOnce for BufferedStream<I>where
I: StreamOnce + Positioned,
I::Item: Clone + PartialEq,
impl<I> StreamOnce for BufferedStream<I>where I: StreamOnce + Positioned, I::Item: Clone + PartialEq,
§type Item = <I as StreamOnce>::Item
type Item = <I as StreamOnce>::Item
§type Range = <I as StreamOnce>::Range
type Range = <I as StreamOnce>::Range
Self::Item for this type.§type Position = <I as StreamOnce>::Position
type Position = <I as StreamOnce>::Position
Ord is required to allow parsers to determine which of two positions are further ahead.type Error = <I as StreamOnce>::Error
source§fn uncons(&mut self) -> Result<I::Item, StreamErrorFor<Self>>
fn uncons(&mut self) -> Result<I::Item, StreamErrorFor<Self>>
Err if no element could be retrieved.source§fn is_partial(&self) -> bool
fn is_partial(&self) -> bool
true if this stream only contains partial input. Read more