pub struct CtxtInterners<'tcx> {
Show 20 fields arena: &'tcx WorkerLocal<Arena<'tcx>>, type_: ShardedHashMap<InternedInSet<'tcx, WithCachedTypeInfo<TyKind<'tcx>>>, ()>, const_lists: ShardedHashMap<InternedInSet<'tcx, List<Const<'tcx>>>, ()>, args: ShardedHashMap<InternedInSet<'tcx, GenericArgs<'tcx>>, ()>, type_lists: ShardedHashMap<InternedInSet<'tcx, List<Ty<'tcx>>>, ()>, canonical_var_infos: ShardedHashMap<InternedInSet<'tcx, List<CanonicalVarInfo<'tcx>>>, ()>, region: ShardedHashMap<InternedInSet<'tcx, RegionKind<'tcx>>, ()>, poly_existential_predicates: ShardedHashMap<InternedInSet<'tcx, List<PolyExistentialPredicate<'tcx>>>, ()>, predicate: ShardedHashMap<InternedInSet<'tcx, WithCachedTypeInfo<Binder<'tcx, PredicateKind<'tcx>>>>, ()>, clauses: ShardedHashMap<InternedInSet<'tcx, List<Clause<'tcx>>>, ()>, projs: ShardedHashMap<InternedInSet<'tcx, List<ProjectionKind>>, ()>, place_elems: ShardedHashMap<InternedInSet<'tcx, List<PlaceElem<'tcx>>>, ()>, const_: ShardedHashMap<InternedInSet<'tcx, ConstData<'tcx>>, ()>, const_allocation: ShardedHashMap<InternedInSet<'tcx, Allocation>, ()>, bound_variable_kinds: ShardedHashMap<InternedInSet<'tcx, List<BoundVariableKind>>, ()>, layout: ShardedHashMap<InternedInSet<'tcx, LayoutS>, ()>, adt_def: ShardedHashMap<InternedInSet<'tcx, AdtDefData>, ()>, external_constraints: ShardedHashMap<InternedInSet<'tcx, ExternalConstraintsData<'tcx>>, ()>, predefined_opaques_in_body: ShardedHashMap<InternedInSet<'tcx, PredefinedOpaquesData<'tcx>>, ()>, fields: ShardedHashMap<InternedInSet<'tcx, List<FieldIdx>>, ()>,
}

Fields§

§arena: &'tcx WorkerLocal<Arena<'tcx>>

The arena that types, regions, etc. are allocated from.

§type_: ShardedHashMap<InternedInSet<'tcx, WithCachedTypeInfo<TyKind<'tcx>>>, ()>§const_lists: ShardedHashMap<InternedInSet<'tcx, List<Const<'tcx>>>, ()>§args: ShardedHashMap<InternedInSet<'tcx, GenericArgs<'tcx>>, ()>§type_lists: ShardedHashMap<InternedInSet<'tcx, List<Ty<'tcx>>>, ()>§canonical_var_infos: ShardedHashMap<InternedInSet<'tcx, List<CanonicalVarInfo<'tcx>>>, ()>§region: ShardedHashMap<InternedInSet<'tcx, RegionKind<'tcx>>, ()>§poly_existential_predicates: ShardedHashMap<InternedInSet<'tcx, List<PolyExistentialPredicate<'tcx>>>, ()>§predicate: ShardedHashMap<InternedInSet<'tcx, WithCachedTypeInfo<Binder<'tcx, PredicateKind<'tcx>>>>, ()>§clauses: ShardedHashMap<InternedInSet<'tcx, List<Clause<'tcx>>>, ()>§projs: ShardedHashMap<InternedInSet<'tcx, List<ProjectionKind>>, ()>§place_elems: ShardedHashMap<InternedInSet<'tcx, List<PlaceElem<'tcx>>>, ()>§const_: ShardedHashMap<InternedInSet<'tcx, ConstData<'tcx>>, ()>§const_allocation: ShardedHashMap<InternedInSet<'tcx, Allocation>, ()>§bound_variable_kinds: ShardedHashMap<InternedInSet<'tcx, List<BoundVariableKind>>, ()>§layout: ShardedHashMap<InternedInSet<'tcx, LayoutS>, ()>§adt_def: ShardedHashMap<InternedInSet<'tcx, AdtDefData>, ()>§external_constraints: ShardedHashMap<InternedInSet<'tcx, ExternalConstraintsData<'tcx>>, ()>§predefined_opaques_in_body: ShardedHashMap<InternedInSet<'tcx, PredefinedOpaquesData<'tcx>>, ()>§fields: ShardedHashMap<InternedInSet<'tcx, List<FieldIdx>>, ()>

Implementations§

source§

impl<'tcx> CtxtInterners<'tcx>

source

fn new(arena: &'tcx WorkerLocal<Arena<'tcx>>) -> CtxtInterners<'tcx>

source

fn intern_ty( &self, kind: TyKind<'tcx>, sess: &Session, untracked: &Untracked ) -> Ty<'tcx>

Interns a type. (Use mk_* functions instead, where possible.)

source

fn stable_hash<'a, T: HashStable<StableHashingContext<'a>>>( &self, flags: &FlagComputation, sess: &'a Session, untracked: &'a Untracked, val: &T ) -> Fingerprint

source

fn intern_predicate( &self, kind: Binder<'tcx, PredicateKind<'tcx>>, sess: &Session, untracked: &Untracked ) -> Predicate<'tcx>

Interns a predicate. (Use mk_predicate instead, where possible.)

Auto Trait Implementations§

§

impl<'tcx> !RefUnwindSafe for CtxtInterners<'tcx>

§

impl<'tcx> !Send for CtxtInterners<'tcx>

§

impl<'tcx> !Sync for CtxtInterners<'tcx>

§

impl<'tcx> Unpin for CtxtInterners<'tcx>

§

impl<'tcx> !UnwindSafe for CtxtInterners<'tcx>

Blanket Implementations§

source§

impl<T> Aligned for T

source§

const ALIGN: Alignment = _

Alignment of Self.
source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T, R> CollectAndApply<T, R> for T

source§

fn collect_and_apply<I, F>(iter: I, f: F) -> Rwhere I: Iterator<Item = T>, F: FnOnce(&[T]) -> R,

Equivalent to f(&iter.collect::<Vec<_>>()).

§

type Output = R

source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<P> IntoQueryParam<P> for P

source§

impl<T> MaybeResult<T> for T

§

type Error = !

source§

fn from(_: Result<T, <T as MaybeResult<T>>::Error>) -> T

source§

fn to_result(self) -> Result<T, <T as MaybeResult<T>>::Error>

source§

impl<'tcx, T> ToPredicate<'tcx, T> for T

source§

fn to_predicate(self, _tcx: TyCtxt<'tcx>) -> T

source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<Tcx, T> Value<Tcx> for Twhere Tcx: DepContext,

source§

default fn from_cycle_error( tcx: Tcx, cycle: &[QueryInfo], _guar: ErrorGuaranteed ) -> T

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: 768 bytes