Struct rustdoc::core::DocContext [−][src]
pub(crate) struct DocContext<'tcx> {Show 16 fields
pub(crate) tcx: TyCtxt<'tcx>,
pub(crate) resolver: Rc<RefCell<BoxedResolver>>,
pub(crate) param_env: ParamEnv<'tcx>,
pub(crate) external_traits: Rc<RefCell<FxHashMap<DefId, TraitWithExtraInfo>>>,
pub(crate) active_extern_traits: FxHashSet<DefId>,
pub(crate) ty_substs: FxHashMap<DefId, Type>,
pub(crate) lt_substs: FxHashMap<DefId, Lifetime>,
pub(crate) ct_substs: FxHashMap<DefId, Constant>,
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) module_trait_cache: FxHashMap<DefId, FxHashSet<DefId>>,
pub(crate) cache: Cache,
pub(crate) inlined: FxHashSet<ItemId>,
pub(crate) output_format: OutputFormat,
}
Fields
tcx: TyCtxt<'tcx>
resolver: Rc<RefCell<BoxedResolver>>
Name resolver. Used for intra-doc links.
The Rc<RefCell<...>>
wrapping is needed because that is what’s returned by
Queries::expansion()
.
param_env: ParamEnv<'tcx>
Used for normalization.
Most of this logic is copied from rustc_lint::late.
external_traits: Rc<RefCell<FxHashMap<DefId, TraitWithExtraInfo>>>
Later on moved through clean::Crate
into cache
active_extern_traits: FxHashSet<DefId>
Used while populating external_traits
to ensure we don’t process the same trait twice at
the same time.
ty_substs: FxHashMap<DefId, Type>
Table DefId
of type parameter -> substituted type
lt_substs: FxHashMap<DefId, Lifetime>
Table DefId
of lifetime parameter -> substituted lifetime
ct_substs: FxHashMap<DefId, Constant>
Table DefId
of const parameter -> substituted const
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: RenderOptions
The options given to rustdoc that could be relevant to a pass.
module_trait_cache: FxHashMap<DefId, FxHashSet<DefId>>
The traits in scope for a given module.
See collect_intra_doc_links::traits_implemented_by
for more details.
map<module, set<trait>>
cache: Cache
This 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: OutputFormat
Used by calculate_doc_coverage
.
Implementations
pub(crate) fn with_param_env<T, F: FnOnce(&mut Self) -> T>(
&mut self,
def_id: DefId,
f: F
) -> T
Call the closure with the given parameters set as the substitutions for a type alias’ RHS.
Auto Trait Implementations
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
Mutably borrows from an owned value. Read more
Instruments this type with the provided Span
, returning an
Instrumented
wrapper. Read more
pub fn vzip(self) -> V
Attaches the provided Subscriber
to this type, returning a
WithDispatch
wrapper. Read more
Attaches the current default Subscriber
to this type, returning a
WithDispatch
wrapper. 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: 1272 bytes