Enum rustc_resolve::macros::MacroRulesScope [−][src]
pub enum MacroRulesScope<'a> {
Empty,
Binding(&'a MacroRulesBinding<'a>),
Invocation(LocalExpnId),
}
Expand description
The scope introduced by a macro_rules!
macro.
This starts at the macro’s definition and ends at the end of the macro’s parent
module (named or unnamed), or even further if it escapes with #[macro_use]
.
Some macro invocations need to introduce macro_rules
scopes too because they
can potentially expand into macro definitions.
Variants
Empty “root” scope at the crate start containing no names.
Binding(&'a MacroRulesBinding<'a>)
The scope introduced by a macro_rules!
macro definition.
Tuple Fields of Binding
0: &'a MacroRulesBinding<'a>
Invocation(LocalExpnId)
The scope introduced by a macro invocation that can potentially
create a macro_rules!
macro definition.
Tuple Fields of Invocation
0: LocalExpnId
Trait Implementations
Auto Trait Implementations
impl<'a> !RefUnwindSafe for MacroRulesScope<'a>
impl<'a> !Send for MacroRulesScope<'a>
impl<'a> !Sync for MacroRulesScope<'a>
impl<'a> Unpin for MacroRulesScope<'a>
impl<'a> !UnwindSafe for MacroRulesScope<'a>
Blanket Implementations
Mutably borrows from an owned value. Read more
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
Size for each variant:
Empty
: 0 bytesBinding
: 12 bytesInvocation
: 4 bytes