Struct rustc_expand::expand::MacroExpander [−][src]
Fields
cx: &'a mut ExtCtxt<'b>
monotonic: bool
Implementations
fn collect_invocations(
&mut self,
fragment: AstFragment,
extra_placeholders: &[NodeId]
) -> (AstFragment, Vec<(Invocation, Option<Lrc<SyntaxExtension>>)>)
fn collect_invocations(
&mut self,
fragment: AstFragment,
extra_placeholders: &[NodeId]
) -> (AstFragment, Vec<(Invocation, Option<Lrc<SyntaxExtension>>)>)
Collects all macro invocations reachable at this time in this AST fragment, and replace
them with “placeholders” - dummy macro invocations with specially crafted NodeId
s.
Then call into resolver that builds a skeleton (“reduced graph”) of the fragment and
prepares data for resolving paths of macro invocations.
A macro’s expansion does not fit in this fragment kind. For example, a non-type macro in a type position.
fn expand_invoc(
&mut self,
invoc: Invocation,
ext: &SyntaxExtensionKind
) -> ExpandResult<AstFragment, Invocation>
fn parse_ast_fragment(
&mut self,
toks: TokenStream,
kind: AstFragmentKind,
path: &Path,
span: Span
) -> AstFragment
Auto Trait Implementations
impl<'a, 'b> !RefUnwindSafe for MacroExpander<'a, 'b>
impl<'a, 'b> !Send for MacroExpander<'a, 'b>
impl<'a, 'b> !Sync for MacroExpander<'a, 'b>
impl<'a, 'b> Unpin for MacroExpander<'a, 'b> where
'b: 'a,
impl<'a, 'b> !UnwindSafe for MacroExpander<'a, 'b>
Blanket Implementations
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: 16 bytes