Enum rustc_ast::tokenstream::TokenTree
source · pub enum TokenTree {
Token(Token, Spacing),
Delimited(DelimSpan, DelimSpacing, Delimiter, TokenStream),
}
Expand description
When the main Rust parser encounters a syntax-extension invocation, it parses the arguments to the invocation as a token tree. This is a very loose structure, such that all sorts of different AST fragments can be passed to syntax extensions using a uniform type.
If the syntax extension is an MBE macro, it will attempt to match its
LHS token tree against the provided token tree, and if it finds a
match, will transcribe the RHS token tree, splicing in any captured
macro_parser::matched_nonterminals
into the SubstNt
s it finds.
The RHS of an MBE macro is the only place SubstNt
s are substituted.
Nothing special happens to misnamed or misplaced SubstNt
s.
Variants§
Token(Token, Spacing)
A single token. Should never be OpenDelim
or CloseDelim
, because
delimiters are implicitly represented by Delimited
.
Delimited(DelimSpan, DelimSpacing, Delimiter, TokenStream)
A delimited sequence of token trees.
Implementations§
source§impl TokenTree
impl TokenTree
sourcepub fn eq_unspanned(&self, other: &TokenTree) -> bool
pub fn eq_unspanned(&self, other: &TokenTree) -> bool
Checks if this TokenTree
is equal to the other, regardless of span/spacing information.
sourcepub fn token_alone(kind: TokenKind, span: Span) -> TokenTree
pub fn token_alone(kind: TokenKind, span: Span) -> TokenTree
Create a TokenTree::Token
with alone spacing.
sourcepub fn token_joint(kind: TokenKind, span: Span) -> TokenTree
pub fn token_joint(kind: TokenKind, span: Span) -> TokenTree
Create a TokenTree::Token
with joint spacing.
Create a TokenTree::Token
with joint-hidden spacing.
pub fn uninterpolate(&self) -> Cow<'_, TokenTree>
Trait Implementations§
source§impl<__D: SpanDecoder> Decodable<__D> for TokenTree
impl<__D: SpanDecoder> Decodable<__D> for TokenTree
source§impl<__E: SpanEncoder> Encodable<__E> for TokenTree
impl<__E: SpanEncoder> Encodable<__E> for TokenTree
source§impl FromIterator<TokenTree> for TokenStream
impl FromIterator<TokenTree> for TokenStream
source§impl<__CTX> HashStable<__CTX> for TokenTreewhere
__CTX: HashStableContext,
impl<__CTX> HashStable<__CTX> for TokenTreewhere
__CTX: HashStableContext,
fn hash_stable(&self, __hcx: &mut __CTX, __hasher: &mut StableHasher)
source§impl PartialEq for TokenTree
impl PartialEq for TokenTree
impl StructuralPartialEq for TokenTree
Auto Trait Implementations§
impl DynSend for TokenTree
impl DynSync for TokenTree
impl Freeze for TokenTree
impl !RefUnwindSafe for TokenTree
impl !Send for TokenTree
impl !Sync for TokenTree
impl Unpin for TokenTree
impl !UnwindSafe for TokenTree
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
source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
§impl<T> Pointable for T
impl<T> Pointable for T
source§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
source§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
source§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
impl<'a, T> Captures<'a> for Twhere
T: ?Sized,
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...)
attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 32 bytes
Size for each variant:
Token
: 31 bytesDelimited
: 31 bytes