winnow::stream

Trait Stream

source
pub trait Stream: Offset<Self::Checkpoint> + Debug {
    type Token: Debug;
    type Slice: Debug;
    type IterOffsets: Iterator<Item = (usize, Self::Token)>;
    type Checkpoint: Offset + Clone + Debug;

Show 13 methods // Required methods fn iter_offsets(&self) -> Self::IterOffsets; fn eof_offset(&self) -> usize; fn next_token(&mut self) -> Option<Self::Token>; fn offset_for<P>(&self, predicate: P) -> Option<usize> where P: Fn(Self::Token) -> bool; fn offset_at(&self, tokens: usize) -> Result<usize, Needed>; fn next_slice(&mut self, offset: usize) -> Self::Slice; fn checkpoint(&self) -> Self::Checkpoint; fn reset(&mut self, checkpoint: &Self::Checkpoint); fn raw(&self) -> &dyn Debug; // Provided methods fn peek_token(&self) -> Option<(Self, Self::Token)> where Self: Clone { ... } fn peek_slice(&self, offset: usize) -> (Self, Self::Slice) where Self: Clone { ... } fn finish(&mut self) -> Self::Slice { ... } fn peek_finish(&self) -> (Self, Self::Slice) where Self: Clone { ... }
}
Expand description

Core definition for parser input state

Required Associated Types§

source

type Token: Debug

The smallest unit being parsed

Example: u8 for &[u8] or char for &str

source

type Slice: Debug

Sequence of Tokens

Example: &[u8] for Located<&[u8]> or &str for Located<&str>

source

type IterOffsets: Iterator<Item = (usize, Self::Token)>

Iterate with the offset from the current location

source

type Checkpoint: Offset + Clone + Debug

A parse location within the stream

Required Methods§

source

fn iter_offsets(&self) -> Self::IterOffsets

Iterate with the offset from the current location

source

fn eof_offset(&self) -> usize

Returns the offset to the end of the input

source

fn next_token(&mut self) -> Option<Self::Token>

Split off the next token from the input

source

fn offset_for<P>(&self, predicate: P) -> Option<usize>
where P: Fn(Self::Token) -> bool,

Finds the offset of the next matching token

source

fn offset_at(&self, tokens: usize) -> Result<usize, Needed>

Get the offset for the number of tokens into the stream

This means “0 tokens” will return 0 offset

source

fn next_slice(&mut self, offset: usize) -> Self::Slice

Split off a slice of tokens from the input

Note: For inputs with variable width tokens, like &str’s char, offset might not correspond with the number of tokens. To get a valid offset, use:

§Panic

This will panic if

  • Indexes must be within bounds of the original input;
  • Indexes must uphold invariants of the stream, like for str they must lie on UTF-8 sequence boundaries.
source

fn checkpoint(&self) -> Self::Checkpoint

Save the current parse location within the stream

source

fn reset(&mut self, checkpoint: &Self::Checkpoint)

Revert the stream to a prior Self::Checkpoint

§Panic

May panic if an invalid Self::Checkpoint is provided

source

fn raw(&self) -> &dyn Debug

Return the inner-most stream

Provided Methods§

source

fn peek_token(&self) -> Option<(Self, Self::Token)>
where Self: Clone,

Split off the next token from the input

source

fn peek_slice(&self, offset: usize) -> (Self, Self::Slice)
where Self: Clone,

Split off a slice of tokens from the input

source

fn finish(&mut self) -> Self::Slice

Advance to the end of the stream

source

fn peek_finish(&self) -> (Self, Self::Slice)
where Self: Clone,

Advance to the end of the stream

Object Safety§

This trait is not object safe.

Implementations on Foreign Types§

source§

impl<'i> Stream for &'i str

source§

type Token = char

source§

type Slice = &'i str

source§

type IterOffsets = CharIndices<'i>

source§

type Checkpoint = Checkpoint<&'i str, &'i str>

source§

fn iter_offsets(&self) -> Self::IterOffsets

source§

fn eof_offset(&self) -> usize

source§

fn next_token(&mut self) -> Option<Self::Token>

source§

fn offset_for<P>(&self, predicate: P) -> Option<usize>
where P: Fn(Self::Token) -> bool,

source§

fn offset_at(&self, tokens: usize) -> Result<usize, Needed>

source§

fn next_slice(&mut self, offset: usize) -> Self::Slice

source§

fn checkpoint(&self) -> Self::Checkpoint

source§

fn reset(&mut self, checkpoint: &Self::Checkpoint)

source§

fn raw(&self) -> &dyn Debug

source§

impl<'i, T> Stream for &'i [T]
where T: Clone + Debug,

source§

type Token = T

source§

type Slice = &'i [T]

source§

type IterOffsets = Enumerate<Cloned<Iter<'i, T>>>

source§

type Checkpoint = Checkpoint<&'i [T], &'i [T]>

source§

fn iter_offsets(&self) -> Self::IterOffsets

source§

fn eof_offset(&self) -> usize

source§

fn next_token(&mut self) -> Option<Self::Token>

source§

fn offset_for<P>(&self, predicate: P) -> Option<usize>
where P: Fn(Self::Token) -> bool,

source§

fn offset_at(&self, tokens: usize) -> Result<usize, Needed>

source§

fn next_slice(&mut self, offset: usize) -> Self::Slice

source§

fn checkpoint(&self) -> Self::Checkpoint

source§

fn reset(&mut self, checkpoint: &Self::Checkpoint)

source§

fn raw(&self) -> &dyn Debug

source§

impl<I> Stream for (I, usize)
where I: Stream<Token = u8> + Clone,

source§

type Token = bool

source§

type Slice = (<I as Stream>::Slice, usize, usize)

source§

type IterOffsets = BitOffsets<I>

source§

type Checkpoint = Checkpoint<(<I as Stream>::Checkpoint, usize), (I, usize)>

source§

fn iter_offsets(&self) -> Self::IterOffsets

source§

fn eof_offset(&self) -> usize

source§

fn next_token(&mut self) -> Option<Self::Token>

source§

fn offset_for<P>(&self, predicate: P) -> Option<usize>
where P: Fn(Self::Token) -> bool,

source§

fn offset_at(&self, tokens: usize) -> Result<usize, Needed>

source§

fn next_slice(&mut self, offset: usize) -> Self::Slice

source§

fn checkpoint(&self) -> Self::Checkpoint

source§

fn reset(&mut self, checkpoint: &Self::Checkpoint)

source§

fn raw(&self) -> &dyn Debug

Implementors§