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