Struct rustc_resolve::imports::ImportData
source · pub(crate) struct ImportData<'a> {
pub kind: ImportKind<'a>,
pub root_id: NodeId,
pub use_span: Span,
pub use_span_with_attributes: Span,
pub has_attributes: bool,
pub span: Span,
pub root_span: Span,
pub parent_scope: ParentScope<'a>,
pub module_path: Vec<Segment>,
pub imported_module: Cell<Option<ModuleOrUniformRoot<'a>>>,
pub vis: Cell<Option<Visibility>>,
pub used: Cell<Option<Used>>,
}
Expand description
One import.
Fields§
§kind: ImportKind<'a>
§root_id: NodeId
Node ID of the “root” use item – this is always the same as ImportKind
’s id
(if it exists) except in the case of “nested” use trees, in which case
it will be the ID of the root use tree. e.g., in the example
use foo::bar::{a, b}
this would be the ID of the use foo::bar
UseTree
node.
In case of imports without their own node ID it’s the closest node that can be used,
for example, for reporting lints.
use_span: Span
Span of the entire use statement.
use_span_with_attributes: Span
Span of the entire use statement with attributes.
has_attributes: bool
Did the use statement have any attributes?
span: Span
Span of this use tree.
root_span: Span
Span of the root use tree (see root_id
).
parent_scope: ParentScope<'a>
§module_path: Vec<Segment>
§imported_module: Cell<Option<ModuleOrUniformRoot<'a>>>
The resolution of module_path
.
vis: Cell<Option<Visibility>>
§used: Cell<Option<Used>>
Implementations§
Trait Implementations§
source§impl<'a> Clone for ImportData<'a>
impl<'a> Clone for ImportData<'a>
source§fn clone(&self) -> ImportData<'a>
fn clone(&self) -> ImportData<'a>
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreAuto Trait Implementations§
impl<'a> !DynSend for ImportData<'a>
impl<'a> !DynSync for ImportData<'a>
impl<'a> !Freeze for ImportData<'a>
impl<'a> !RefUnwindSafe for ImportData<'a>
impl<'a> !Send for ImportData<'a>
impl<'a> !Sync for ImportData<'a>
impl<'a> Unpin for ImportData<'a>
impl<'a> !UnwindSafe for ImportData<'a>
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, R> CollectAndApply<T, R> for T
impl<T, R> CollectAndApply<T, R> for T
§impl<T> Filterable for T
impl<T> Filterable for 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>
source§impl<P> IntoQueryParam<P> for P
impl<P> IntoQueryParam<P> for P
fn into_query_param(self) -> P
source§impl<T> MaybeResult<T> for T
impl<T> MaybeResult<T> for T
§impl<T> Pointable for T
impl<T> Pointable for T
source§impl<'tcx, T> ToPredicate<'tcx, T> for T
impl<'tcx, T> ToPredicate<'tcx, T> for T
fn to_predicate(self, _tcx: TyCtxt<'tcx>) -> T
source§impl<Tcx, T> Value<Tcx> for Twhere
Tcx: DepContext,
impl<Tcx, T> Value<Tcx> for Twhere
Tcx: DepContext,
default fn from_cycle_error( tcx: Tcx, cycle_error: &CycleError, _guar: ErrorGuaranteed ) -> 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,
impl<T> ErasedDestructor for Twhere
T: 'static,
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: 232 bytes