pub struct GroupContaining<C> {
pub delimiter: Delimiter,
pub content: C,
}
Expand description
Any kind of Group G
with parseable content C
. The content C
must parse exhaustive,
a EndOfStream
is automatically implied.
Fields§
§delimiter: Delimiter
The delimiters around the group.
content: C
The content of the group.
Implementations§
Source§impl<C> GroupContaining<C>
impl<C> GroupContaining<C>
Sourcepub const fn new(delimiter: Delimiter, content: C) -> GroupContaining<C>
pub const fn new(delimiter: Delimiter, content: C) -> GroupContaining<C>
Create a new GroupContaining
instance.
§Example
let group = GroupContaining::new(
Delimiter::Parenthesis,
Literal::i32_unsuffixed(123),
);
Trait Implementations§
Source§impl<C> Clone for GroupContaining<C>where
C: Clone,
impl<C> Clone for GroupContaining<C>where
C: Clone,
Source§fn clone(&self) -> GroupContaining<C>
fn clone(&self) -> GroupContaining<C>
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreSource§impl<C> Debug for GroupContaining<C>where
C: Debug,
impl<C> Debug for GroupContaining<C>where
C: Debug,
Source§impl<C> From<GroupContaining<C>> for TokenTreewhere
C: ToTokens,
impl<C> From<GroupContaining<C>> for TokenTreewhere
C: ToTokens,
Source§fn from(group: GroupContaining<C>) -> TokenTree
fn from(group: GroupContaining<C>) -> TokenTree
Converts to this type from the input type.
Source§impl<C> GroupDelimiter for GroupContaining<C>
impl<C> GroupDelimiter for GroupContaining<C>
Source§impl<C> Parser for GroupContaining<C>where
C: Parse,
impl<C> Parser for GroupContaining<C>where
C: Parse,
Source§fn parser(
tokens: &mut ShadowCountedIter<'_, <TokenStream as IntoIterator>::IntoIter>,
) -> Result<GroupContaining<C>, Error>
fn parser( tokens: &mut ShadowCountedIter<'_, <TokenStream as IntoIterator>::IntoIter>, ) -> Result<GroupContaining<C>, 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 moreSource§impl<C> ToTokens for GroupContaining<C>where
C: ToTokens,
impl<C> ToTokens for GroupContaining<C>where
C: ToTokens,
Source§fn to_tokens(&self, tokens: &mut TokenStream)
fn to_tokens(&self, tokens: &mut TokenStream)
Write
&self
to the given TokenStream
.Source§fn to_token_iter(
&self,
) -> ShadowCountedIter<'_, <TokenStream as IntoIterator>::IntoIter> ⓘ
fn to_token_iter( &self, ) -> ShadowCountedIter<'_, <TokenStream as IntoIterator>::IntoIter> ⓘ
Convert
&self
into a TokenIter
object.Source§fn into_token_iter<'a>(
self,
) -> ShadowCountedIter<'a, <TokenStream as IntoIterator>::IntoIter> ⓘwhere
Self: Sized,
fn into_token_iter<'a>(
self,
) -> ShadowCountedIter<'a, <TokenStream as IntoIterator>::IntoIter> ⓘwhere
Self: Sized,
Convert
self
into a TokenIter
object.Source§fn to_token_stream(&self) -> TokenStream
fn to_token_stream(&self) -> TokenStream
Convert
&self
into a TokenStream
object.Source§fn into_token_stream(self) -> TokenStreamwhere
Self: Sized,
fn into_token_stream(self) -> TokenStreamwhere
Self: Sized,
Convert
self
into a TokenStream
object.Auto Trait Implementations§
impl<C> Freeze for GroupContaining<C>where
C: Freeze,
impl<C> RefUnwindSafe for GroupContaining<C>where
C: RefUnwindSafe,
impl<C> Send for GroupContaining<C>where
C: Send,
impl<C> Sync for GroupContaining<C>where
C: Sync,
impl<C> Unpin for GroupContaining<C>where
C: Unpin,
impl<C> UnwindSafe for GroupContaining<C>where
C: 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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Parse for Twhere
T: Parser,
impl<T> Parse for Twhere
T: Parser,
Source§fn parse(
tokens: &mut ShadowCountedIter<'_, <TokenStream as IntoIterator>::IntoIter>,
) -> Result<Self, Error>
fn parse( tokens: &mut ShadowCountedIter<'_, <TokenStream as IntoIterator>::IntoIter>, ) -> 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 moreSource§fn parse_all(
tokens: &mut ShadowCountedIter<'_, <TokenStream as IntoIterator>::IntoIter>,
) -> Result<Self, Error>
fn parse_all( tokens: &mut ShadowCountedIter<'_, <TokenStream as IntoIterator>::IntoIter>, ) -> 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 moreSource§fn parse_with<T>(
tokens: &mut ShadowCountedIter<'_, <TokenStream as IntoIterator>::IntoIter>,
f: impl FnOnce(Self, &mut ShadowCountedIter<'_, <TokenStream as IntoIterator>::IntoIter>) -> Result<T, Error>,
) -> Result<T, Error>
fn parse_with<T>( tokens: &mut ShadowCountedIter<'_, <TokenStream as IntoIterator>::IntoIter>, f: impl FnOnce(Self, &mut ShadowCountedIter<'_, <TokenStream as IntoIterator>::IntoIter>) -> 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