Struct rustc_trait_selection::solve::eval_ctxt::NestedGoals
source · pub(super) struct NestedGoals<'tcx> {
pub(super) normalizes_to_hack_goal: Option<Goal<'tcx, ProjectionPredicate<'tcx>>>,
pub(super) goals: Vec<Goal<'tcx, Predicate<'tcx>>>,
}
Fields§
§normalizes_to_hack_goal: Option<Goal<'tcx, ProjectionPredicate<'tcx>>>
This normalizes-to goal that is treated specially during the evaluation loop. In each iteration we take the RHS of the projection, replace it with a fresh inference variable, and only after evaluating that goal do we equate the fresh inference variable with the actual RHS of the predicate.
This is both to improve caching, and to avoid using the RHS of the projection predicate to influence the normalizes-to candidate we select.
This is not a ‘real’ nested goal. We must not forget to replace the RHS with a fresh inference variable when we evaluate this goal. That can result in a trait solver cycle. This would currently result in overflow but can be can be unsound with more powerful coinduction in the future.
goals: Vec<Goal<'tcx, Predicate<'tcx>>>
The rest of the goals which have not yet processed or remain ambiguous.
Implementations§
Trait Implementations§
source§impl<'tcx> Clone for NestedGoals<'tcx>
impl<'tcx> Clone for NestedGoals<'tcx>
source§fn clone(&self) -> NestedGoals<'tcx>
fn clone(&self) -> NestedGoals<'tcx>
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreAuto Trait Implementations§
impl<'tcx> !RefUnwindSafe for NestedGoals<'tcx>
impl<'tcx> Send for NestedGoals<'tcx>
impl<'tcx> Sync for NestedGoals<'tcx>
impl<'tcx> Unpin for NestedGoals<'tcx>
impl<'tcx> !UnwindSafe for NestedGoals<'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
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: 56 bytes