LazyVecUntil

Struct LazyVecUntil 

Source
pub struct LazyVecUntil<T, S> {
    pub vec: Vec<T>,
    /* private fields */
}
Expand description

A Vec<T> that is filled up to the first appearance of an terminating S. This S may be a subset of T, thus parsing become lazy. Unlike LazyVec this variant does not consume the final terminator. This is the same as Vec<Cons<Except<S>,T>>> but more convenient.

§Example

Parse anything until a ;.

let mut token_iter = "foo bar ; baz ;".to_token_iter();

type Example = LazyVecUntil<TokenTree, Semicolon>;

let _example = Example::parse(&mut token_iter).unwrap();
let _example = Semicolon::parse(&mut token_iter).unwrap();
let _example = Example::parse(&mut token_iter).unwrap();
let _example = Semicolon::parse(&mut token_iter).unwrap();

Fields§

§vec: Vec<T>

The vector of repeating T

Trait Implementations§

Source§

impl<T, S> Clone for LazyVecUntil<T, S>
where T: Clone, S: Clone,

Source§

fn clone(&self) -> LazyVecUntil<T, S>

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<T, S> Debug for LazyVecUntil<T, S>
where T: Debug, S: Debug,

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

impl<T, S> IntoIterator for LazyVecUntil<T, S>

Source§

type Item = T

The type of the elements being iterated over.
Source§

type IntoIter = IntoIter<<LazyVecUntil<T, S> as IntoIterator>::Item>

Which kind of iterator are we turning this into?
Source§

fn into_iter(self) -> <LazyVecUntil<T, S> as IntoIterator>::IntoIter

Creates an iterator from a value. Read more
Source§

impl<T, S> Parser for LazyVecUntil<T, S>
where T: Parse, S: Parse,

Source§

fn parser(tokens: &mut TokenIter) -> Result<LazyVecUntil<T, S>, Error>

The actual parsing function that must be implemented. This mutates the tokens iterator directly. It should not be called from user code except for implementing parsers itself and then only when the rules below are followed. Read more
Source§

impl<T, S> RangedRepeats for LazyVecUntil<T, S>
where T: Parse, S: Parse,

Source§

fn parse_repeats( tokens: &mut TokenIter, min: usize, max: usize, ) -> Result<LazyVecUntil<T, S>, Error>

Parse at least min and up to max (inclusive) elements.
Source§

fn parse_any(tokens: &mut TokenIter) -> Result<Self, Error>

Parse any number of elements.
Source§

fn parse_many(tokens: &mut TokenIter) -> Result<Self, Error>

Parse at least one element.
Source§

fn parse_optional(tokens: &mut TokenIter) -> Result<Self, Error>

Parse zero or one element.
Source§

fn parse_exactly(tokens: &mut TokenIter, n: usize) -> Result<Self, Error>

Parse exactly n elements.
Source§

fn parse_at_most(tokens: &mut TokenIter, n: usize) -> Result<Self, Error>

Parse at most n elements.
Source§

fn parse_at_least(tokens: &mut TokenIter, n: usize) -> Result<Self, Error>

Parse at least n elements.
Source§

impl<T, S> ToTokens for LazyVecUntil<T, S>
where T: ToTokens, S: ToTokens,

Source§

fn to_tokens(&self, tokens: &mut TokenStream)

Write &self to the given TokenStream. Read more
Source§

fn to_token_iter(&self) -> TokenIter

Convert &self into a TokenIter object.
Source§

fn into_token_iter(self) -> TokenIter
where Self: Sized,

Convert self into a TokenIter object.
Source§

fn to_token_stream(&self) -> TokenStream

Convert &self into a TokenStream object.
Source§

fn into_token_stream(self) -> TokenStream
where Self: Sized,

Convert self into a TokenStream object.
Source§

fn tokens_to_string(&self) -> String

Convert &self into a String object. This is mostly used in the test suite to compare the outputs. When the input is a &str then this parses it and returns a normalized String.

Auto Trait Implementations§

§

impl<T, S> Freeze for LazyVecUntil<T, S>

§

impl<T, S> RefUnwindSafe for LazyVecUntil<T, S>

§

impl<T, S> Send for LazyVecUntil<T, S>
where S: Send, T: Send,

§

impl<T, S> Sync for LazyVecUntil<T, S>
where S: Sync, T: Sync,

§

impl<T, S> Unpin for LazyVecUntil<T, S>
where S: Unpin, T: Unpin,

§

impl<T, S> UnwindSafe for LazyVecUntil<T, S>
where S: UnwindSafe, T: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> DynamicTokens for T
where T: Any + ToTokens + Debug,

Source§

fn as_any(&self) -> &(dyn Any + 'static)

Upcasts &DynamicTokens to &dyn Any. This allows us to stay backward compatible with older rust. Rust 1.86 implements upcast coercion.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Parse for T
where T: Parser,

Source§

fn parse(tokens: &mut TokenIter) -> Result<Self, Error>

This is the user facing API to parse grammatical entities. Calls a parser() within a transaction. Commits changes on success and returns the parsed value. Read more
Source§

fn parse_all(tokens: &mut TokenIter) -> Result<Self, Error>

Exhaustive parsing within a transaction. This is a convenience method that implies a EndOfStream at the end. Thus it will error if parsing is not exhaustive. Read more
Source§

fn parse_with<T>( tokens: &mut TokenIter, f: impl FnOnce(Self, &mut TokenIter) -> Result<T, Error>, ) -> Result<T, Error>

Parse a value in a transaction, pass it to a FnOnce(Self, &mut TokenIter) -> Result<T> closure which creates a new result or returns an Error. Read more
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.