Enum rustc_resolve::ModuleOrUniformRoot [−][src]
pub(crate) enum ModuleOrUniformRoot<'a> {
Module(&'a ModuleData<'a>),
CrateRootAndExternPrelude,
ExternPrelude,
CurrentScope,
}
Variants
Module(&'a ModuleData<'a>)
Regular module.
Tuple Fields of Module
0: &'a ModuleData<'a>
Virtual module that denotes resolution in crate root with fallback to extern prelude.
Virtual module that denotes resolution in extern prelude.
Used for paths starting with ::
on 2018 edition.
Virtual module that denotes resolution in current scope. Used only for resolving single-segment imports. The reason it exists is that import paths are always split into two parts, the first of which should be some kind of module.
Implementations
Trait Implementations
Auto Trait Implementations
impl<'a> !RefUnwindSafe for ModuleOrUniformRoot<'a>
impl<'a> !Send for ModuleOrUniformRoot<'a>
impl<'a> !Sync for ModuleOrUniformRoot<'a>
impl<'a> Unpin for ModuleOrUniformRoot<'a>
impl<'a> !UnwindSafe for ModuleOrUniformRoot<'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:
Module
: 8 bytesCrateRootAndExternPrelude
: 0 bytesExternPrelude
: 0 bytesCurrentScope
: 0 bytes