pub enum ProbeKind<'tcx> {
Root {
result: Result<Canonical<TyCtxt<'tcx>, Response<'tcx>>, NoSolution>,
},
TryNormalizeNonRigid {
result: Result<Canonical<TyCtxt<'tcx>, Response<'tcx>>, NoSolution>,
},
NormalizedSelfTyAssembly,
TraitCandidate {
source: CandidateSource,
result: Result<Canonical<TyCtxt<'tcx>, Response<'tcx>>, NoSolution>,
},
UnsizeAssembly,
UpcastProjectionCompatibility,
OpaqueTypeStorageLookup {
result: Result<Canonical<TyCtxt<'tcx>, Response<'tcx>>, NoSolution>,
},
}
Expand description
What kind of probe we’re in. In case the probe represents a candidate, or the final result of the current goal - via ProbeKind::Root - we also store the QueryResult.
Variants§
Root
The root inference context while proving a goal.
TryNormalizeNonRigid
Trying to normalize an alias by at least one step in NormalizesTo
.
NormalizedSelfTyAssembly
Probe entered when normalizing the self ty during candidate assembly
TraitCandidate
A candidate for proving a trait or alias-relate goal.
UnsizeAssembly
Used in the probe that wraps normalizing the non-self type for the unsize trait, which is also structurally matched on.
UpcastProjectionCompatibility
During upcasting from some source object to target object type, used to do a probe to find out what projection type(s) may be used to prove that the source type upholds all of the target type’s object bounds.
OpaqueTypeStorageLookup
Try to unify an opaque type with an existing key in the storage.
Trait Implementations§
source§impl<'tcx> PartialEq for ProbeKind<'tcx>
impl<'tcx> PartialEq for ProbeKind<'tcx>
impl<'tcx> Copy for ProbeKind<'tcx>
impl<'tcx> Eq for ProbeKind<'tcx>
impl<'tcx> StructuralPartialEq for ProbeKind<'tcx>
Auto Trait Implementations§
impl<'tcx> DynSend for ProbeKind<'tcx>
impl<'tcx> DynSync for ProbeKind<'tcx>
impl<'tcx> Freeze for ProbeKind<'tcx>
impl<'tcx> !RefUnwindSafe for ProbeKind<'tcx>
impl<'tcx> Send for ProbeKind<'tcx>
impl<'tcx> Sync for ProbeKind<'tcx>
impl<'tcx> Unpin for ProbeKind<'tcx>
impl<'tcx> !UnwindSafe for ProbeKind<'tcx>
Blanket Implementations§
source§impl<'tcx, T> ArenaAllocatable<'tcx, IsCopy> for Twhere
T: Copy,
impl<'tcx, T> ArenaAllocatable<'tcx, IsCopy> for Twhere
T: Copy,
fn allocate_on<'a>(self, arena: &'a Arena<'tcx>) -> &'a mut T
fn allocate_from_iter<'a>( arena: &'a Arena<'tcx>, iter: impl IntoIterator<Item = T> ) -> &'a mut [T]
source§impl<'tcx, T> ArenaAllocatable<'tcx, IsCopy> for Twhere
T: Copy,
impl<'tcx, T> ArenaAllocatable<'tcx, IsCopy> for Twhere
T: Copy,
fn allocate_on<'a>(self, arena: &'a Arena<'tcx>) -> &'a mut T
fn allocate_from_iter<'a>( arena: &'a Arena<'tcx>, iter: impl IntoIterator<Item = T> ) -> &'a mut [T]
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
source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.source§impl<T> Filterable for T
impl<T> Filterable for T
source§fn filterable(
self,
filter_name: &'static str
) -> RequestFilterDataProvider<T, fn(_: DataRequest<'_>) -> bool>
fn filterable( self, filter_name: &'static str ) -> RequestFilterDataProvider<T, fn(_: DataRequest<'_>) -> bool>
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
source§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,
impl<T> MaybeSendSync for 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: 64 bytes
Size for each variant:
Root
: 56 bytesTryNormalizeNonRigid
: 56 bytesNormalizedSelfTyAssembly
: 0 bytesTraitCandidate
: 64 bytesUnsizeAssembly
: 0 bytesUpcastProjectionCompatibility
: 0 bytesOpaqueTypeStorageLookup
: 56 bytes