pub struct Stream<Input>where
Input: 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 ResetStream
(such as ReadStream
) may
use this as a way to implement ResetStream
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 buffered::Stream
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 buffered::Stream
instance wraps the easy::Stream
instance instead of the other way around.
ⓘ
// DO
buffered::Stream::new(easy::Stream(..), ..)
// DON'T
easy::Stream(buffered::Stream::new(.., ..))
parser.easy_parse(buffered::Stream::new(..));
Implementations§
Trait Implementations§
source§impl<Input> PartialEq for Stream<Input>where
Input: StreamOnce + Positioned + PartialEq,
Input::Token: PartialEq,
Input::Position: PartialEq,
impl<Input> PartialEq for Stream<Input>where
Input: StreamOnce + Positioned + PartialEq,
Input::Token: PartialEq,
Input::Position: PartialEq,
source§impl<Input> Positioned for Stream<Input>where
Input: StreamOnce + Positioned,
impl<Input> Positioned for Stream<Input>where
Input: StreamOnce + Positioned,
source§impl<Input> ResetStream for Stream<Input>where
Input: Positioned,
impl<Input> ResetStream for Stream<Input>where
Input: Positioned,
type Checkpoint = usize
source§fn checkpoint(&self) -> Self::Checkpoint
fn checkpoint(&self) -> Self::Checkpoint
Creates a
Checkpoint
at the current position which can be used to reset the stream
later to the current positionsource§impl<Input> StreamOnce for Stream<Input>
impl<Input> StreamOnce for Stream<Input>
source§type Token = <Input as StreamOnce>::Token
type Token = <Input as StreamOnce>::Token
The type of items which is yielded from this stream.
source§type Range = <Input as StreamOnce>::Range
type Range = <Input as StreamOnce>::Range
The type of a range of items yielded from this stream.
Types which do not a have a way of yielding ranges of items should just use the
Self::Token
for this type.source§type Position = <Input as StreamOnce>::Position
type Position = <Input as StreamOnce>::Position
Type which represents the position in a stream.
Ord
is required to allow parsers to determine which of two positions are further ahead.type Error = <Input as StreamOnce>::Error
source§fn uncons(&mut self) -> Result<Input::Token, StreamErrorFor<Self>>
fn uncons(&mut self) -> Result<Input::Token, StreamErrorFor<Self>>
Takes a stream and removes its first token, yielding the token and the rest of the elements.
Returns
Err
if no element could be retrieved.source§fn is_partial(&self) -> bool
fn is_partial(&self) -> bool
Returns
true
if this stream only contains partial input. Read moreimpl<Input> StructuralPartialEq for Stream<Input>where
Input: StreamOnce + Positioned,
Auto Trait Implementations§
impl<Input> Freeze for Stream<Input>where
Input: Freeze,
impl<Input> RefUnwindSafe for Stream<Input>where
Input: RefUnwindSafe,
<Input as StreamOnce>::Token: RefUnwindSafe,
<Input as StreamOnce>::Position: RefUnwindSafe,
impl<Input> Send for Stream<Input>
impl<Input> Sync for Stream<Input>
impl<Input> Unpin for Stream<Input>
impl<Input> UnwindSafe for Stream<Input>where
Input: UnwindSafe,
<Input as StreamOnce>::Token: UnwindSafe,
<Input as StreamOnce>::Position: UnwindSafe,
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more