pub enum RerunCondition<I>where
I: Interner,{
Never,
AnyOpaqueHasInferAsHidden,
OpaqueInStorage(SmallCopyList<<I as Interner>::LocalDefId>),
OpaqueInStorageOrAnyOpaqueHasInferAsHidden(SmallCopyList<<I as Interner>::LocalDefId>),
Always,
}Expand description
Information about how we accessed opaque types This is what the trait solver does when each states is encountered:
| bail? | rerun goal? | |
|---|---|---|
| never | no | no |
| always | yes | yes |
| [defid in storage] | no | only if any of the defids in the list is in the opaque type storage OR if TypingMode::PostAnalysis |
| opaque with hidden type | no | only if any of the the opaques in the opaque type storage has a hidden type in this list AND if TypingMode::Analysis |
-
“bail” is implemented with
should_bail. If true, we’re abandoning our attempt to canonicalize inTypingMode::ErasedNotCoherence, and should try to return as soon as possible to waste as little time as possible. A rerun will be attempted in the original typing mode. -
Rerun goal is implemented with
should_rerun_after_erased_canonicalization, on theEvalCtxt.
Some variant names contain an Or here. They rerun when any of the two conditions applies
Variants§
Never
AnyOpaqueHasInferAsHidden
Note that this only reruns according to the condition if we are in TypingMode::Analysis.
OpaqueInStorage(SmallCopyList<<I as Interner>::LocalDefId>)
Note: unconditionally reruns in postanalysis
OpaqueInStorageOrAnyOpaqueHasInferAsHidden(SmallCopyList<<I as Interner>::LocalDefId>)
Merges Self::AnyOpaqueHasInferAsHidden and Self::OpaqueInStorage.
Note that just like the unmerged Self::OpaqueInStorage, that part of the
condition only matters in TypingMode::Analysis
Always
Trait Implementations§
Source§impl<I> Clone for RerunCondition<I>where
I: Interner,
impl<I> Clone for RerunCondition<I>where
I: Interner,
Source§fn clone(&self) -> RerunCondition<I>
fn clone(&self) -> RerunCondition<I>
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl<I> Debug for RerunCondition<I>where
I: Interner,
impl<I> Debug for RerunCondition<I>where
I: Interner,
Source§impl<I> Hash for RerunCondition<I>where
I: Interner,
impl<I> Hash for RerunCondition<I>where
I: Interner,
Source§impl<I> PartialEq for RerunCondition<I>where
I: Interner,
impl<I> PartialEq for RerunCondition<I>where
I: Interner,
Source§fn eq(&self, __other: &RerunCondition<I>) -> bool
fn eq(&self, __other: &RerunCondition<I>) -> bool
self and other values to be equal, and is used by ==.Source§impl<I> StableHash for RerunCondition<I>
impl<I> StableHash for RerunCondition<I>
fn stable_hash<__Hcx>(
&self,
__hcx: &mut __Hcx,
__hasher: &mut StableHasher<SipHasher128>,
)where
__Hcx: StableHashCtxt,
Source§impl<I> TypeFoldable<I> for RerunCondition<I>
impl<I> TypeFoldable<I> for RerunCondition<I>
Source§fn try_fold_with<__F>(
self,
__folder: &mut __F,
) -> Result<RerunCondition<I>, <__F as FallibleTypeFolder<I>>::Error>where
__F: FallibleTypeFolder<I>,
fn try_fold_with<__F>(
self,
__folder: &mut __F,
) -> Result<RerunCondition<I>, <__F as FallibleTypeFolder<I>>::Error>where
__F: FallibleTypeFolder<I>,
Source§fn fold_with<__F>(self, __folder: &mut __F) -> RerunCondition<I>where
__F: TypeFolder<I>,
fn fold_with<__F>(self, __folder: &mut __F) -> RerunCondition<I>where
__F: TypeFolder<I>,
Source§impl<I> TypeVisitable<I> for RerunCondition<I>
impl<I> TypeVisitable<I> for RerunCondition<I>
Source§fn visit_with<__V>(
&self,
__visitor: &mut __V,
) -> <__V as TypeVisitor<I>>::Resultwhere
__V: TypeVisitor<I>,
fn visit_with<__V>(
&self,
__visitor: &mut __V,
) -> <__V as TypeVisitor<I>>::Resultwhere
__V: TypeVisitor<I>,
impl<I> Copy for RerunCondition<I>where
I: Interner,
impl<I> Eq for RerunCondition<I>where
I: Interner,
Auto Trait Implementations§
impl<I> DynSend for RerunCondition<I>
impl<I> DynSync for RerunCondition<I>
impl<I> Freeze for RerunCondition<I>
impl<I> RefUnwindSafe for RerunCondition<I>
impl<I> Send for RerunCondition<I>
impl<I> Sync for RerunCondition<I>
impl<I> Unpin for RerunCondition<I>
impl<I> UnsafeUnpin for RerunCondition<I>
impl<I> UnwindSafe for RerunCondition<I>
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(self, arena: &'tcx Arena<'tcx>) -> &'tcx mut T
fn allocate_from_iter( arena: &'tcx Arena<'tcx>, iter: impl IntoIterator<Item = T>, ) -> &'tcx 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(self, arena: &'tcx Arena<'tcx>) -> &'tcx mut T
fn allocate_from_iter( arena: &'tcx Arena<'tcx>, iter: impl IntoIterator<Item = T>, ) -> &'tcx 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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
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> 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<K> IntoQueryKey<K> for K
impl<K> IntoQueryKey<K> for K
Source§fn into_query_key(self) -> K
fn into_query_key(self) -> K
Self to K.
This should always be a very cheap conversion, e.g. LocalDefId::to_def_id.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<I, T, U> Upcast<I, U> for Twhere
U: UpcastFrom<I, T>,
impl<I, T, U> Upcast<I, U> for Twhere
U: UpcastFrom<I, T>,
Source§impl<I, T> UpcastFrom<I, T> for T
impl<I, T> UpcastFrom<I, T> for T
fn upcast_from(from: T, _tcx: I) -> 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<T> ErasedDestructor for Twhere
T: 'static,
Layout§
Note: Unable to compute type layout, possibly due to this type having generic parameters. Layout can only be computed for concrete, fully-instantiated types.