pub(crate) struct DocContext<'tcx> {Show 14 fields
pub(crate) tcx: TyCtxt<'tcx>,
pub(crate) param_env: ParamEnv<'tcx>,
pub(crate) external_traits: FxIndexMap<DefId, Trait>,
pub(crate) active_extern_traits: DefIdSet,
pub(crate) args: DefIdMap<GenericArg>,
pub(crate) current_type_aliases: DefIdMap<usize>,
pub(crate) impl_trait_bounds: FxHashMap<ImplTraitParam, Vec<GenericBound>>,
pub(crate) generated_synthetics: FxHashSet<(Ty<'tcx>, DefId)>,
pub(crate) auto_traits: Vec<DefId>,
pub(crate) render_options: RenderOptions,
pub(crate) cache: Cache,
pub(crate) inlined: FxHashSet<ItemId>,
pub(crate) output_format: OutputFormat,
pub(crate) show_coverage: bool,
}Fields§
§tcx: TyCtxt<'tcx>§param_env: ParamEnv<'tcx>Used for normalization.
Most of this logic is copied from rustc_lint::late.
external_traits: FxIndexMap<DefId, Trait>Later on moved through clean::Crate into cache
active_extern_traits: DefIdSetUsed while populating external_traits to ensure we don’t process the same trait twice at
the same time.
args: DefIdMap<GenericArg>The current set of parameter instantiations for expanding type aliases at the HIR level.
Maps from the DefId of a lifetime or type parameter to the
generic argument it’s currently instantiated to in this context.
current_type_aliases: DefIdMap<usize>§impl_trait_bounds: FxHashMap<ImplTraitParam, Vec<GenericBound>>Table synthetic type parameter for impl Trait in argument position -> bounds
generated_synthetics: FxHashSet<(Ty<'tcx>, DefId)>Auto-trait or blanket impls processed so far, as (self_ty, trait_def_id).
auto_traits: Vec<DefId>§render_options: RenderOptionsThe options given to rustdoc that could be relevant to a pass.
cache: CacheThis same cache is used throughout rustdoc, including in crate::html::render.
inlined: FxHashSet<ItemId>Used by clean::inline to tell if an item has already been inlined.
output_format: OutputFormatUsed by calculate_doc_coverage.
show_coverage: boolUsed by strip_private.
Implementations§
Source§impl<'tcx> DocContext<'tcx>
impl<'tcx> DocContext<'tcx>
pub(crate) fn sess(&self) -> &'tcx Session
pub(crate) fn with_param_env<T, F: FnOnce(&mut Self) -> T>( &mut self, def_id: DefId, f: F, ) -> T
pub(crate) fn typing_env(&self) -> TypingEnv<'tcx>
Sourcepub(crate) fn enter_alias<F, R>(
&mut self,
args: DefIdMap<GenericArg>,
def_id: DefId,
f: F,
) -> Rwhere
F: FnOnce(&mut Self) -> R,
pub(crate) fn enter_alias<F, R>(
&mut self,
args: DefIdMap<GenericArg>,
def_id: DefId,
f: F,
) -> Rwhere
F: FnOnce(&mut Self) -> R,
Call the closure with the given parameters set as the generic parameters for a type alias’ RHS.
Sourcepub(crate) fn as_local_hir_id(tcx: TyCtxt<'_>, item_id: ItemId) -> Option<HirId>
pub(crate) fn as_local_hir_id(tcx: TyCtxt<'_>, item_id: ItemId) -> Option<HirId>
Like tcx.local_def_id_to_hir_id(), but skips calling it on fake DefIds.
(This avoids a slice-index-out-of-bounds panic.)
Sourcepub(crate) fn is_json_output(&self) -> bool
pub(crate) fn is_json_output(&self) -> bool
Returns true if the JSON output format is enabled for generating the crate content.
If another option like --show-coverage is enabled, it will return false.
Auto Trait Implementations§
impl<'tcx> Freeze for DocContext<'tcx>
impl<'tcx> !RefUnwindSafe for DocContext<'tcx>
impl<'tcx> !Send for DocContext<'tcx>
impl<'tcx> !Sync for DocContext<'tcx>
impl<'tcx> Unpin for DocContext<'tcx>
impl<'tcx> !UnwindSafe for DocContext<'tcx>
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>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§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>
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: 1536 bytes