Struct rustc_middle::traits::solve::cache::CacheEntry
source · struct CacheEntry<'tcx> {
success: Option<Success<'tcx>>,
cycle_participants: FxHashSet<CanonicalInput<'tcx>>,
with_overflow: FxHashMap<usize, WithDepNode<QueryResult<'tcx>>>,
}
Expand description
The cache entry for a goal CanonicalInput
.
This contains results whose computation never hit the
recursion limit in success
, and all results which hit
the recursion limit in with_overflow
.
Fields§
§success: Option<Success<'tcx>>
§cycle_participants: FxHashSet<CanonicalInput<'tcx>>
We have to be careful when caching roots of cycles.
See the doc comment of StackEntry::cycle_participants
for more
details.
with_overflow: FxHashMap<usize, WithDepNode<QueryResult<'tcx>>>
Trait Implementations§
source§impl<'tcx> Default for CacheEntry<'tcx>
impl<'tcx> Default for CacheEntry<'tcx>
source§fn default() -> CacheEntry<'tcx>
fn default() -> CacheEntry<'tcx>
Returns the “default value” for a type. Read more
Auto Trait Implementations§
impl<'tcx> !RefUnwindSafe for CacheEntry<'tcx>
impl<'tcx> !Send for CacheEntry<'tcx>
impl<'tcx> !Sync for CacheEntry<'tcx>
impl<'tcx> Unpin for CacheEntry<'tcx>
impl<'tcx> !UnwindSafe for CacheEntry<'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
Mutably borrows from an owned value. Read more
source§impl<T, R> CollectAndApply<T, R> for T
impl<T, R> CollectAndApply<T, R> for T
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<'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: &[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: 120 bytes