Struct rustc_trait_selection::traits::fulfill::FulfillProcessor
source · struct FulfillProcessor<'a, 'tcx> {
selcx: SelectionContext<'a, 'tcx>,
}
Fields§
§selcx: SelectionContext<'a, 'tcx>
Implementations§
source§impl<'a, 'tcx> FulfillProcessor<'a, 'tcx>
impl<'a, 'tcx> FulfillProcessor<'a, 'tcx>
fn process_trait_obligation(
&mut self,
obligation: &PredicateObligation<'tcx>,
trait_obligation: TraitObligation<'tcx>,
stalled_on: &mut Vec<TyOrConstInferVar<'tcx>>
) -> ProcessResult<PendingPredicateObligation<'tcx>, FulfillmentErrorCode<'tcx>>
fn process_projection_obligation(
&mut self,
obligation: &PredicateObligation<'tcx>,
project_obligation: Obligation<'tcx, PolyProjectionPredicate<'tcx>>,
stalled_on: &mut Vec<TyOrConstInferVar<'tcx>>
) -> ProcessResult<PendingPredicateObligation<'tcx>, FulfillmentErrorCode<'tcx>>
Trait Implementations§
source§impl<'a, 'tcx> ObligationProcessor for FulfillProcessor<'a, 'tcx>
impl<'a, 'tcx> ObligationProcessor for FulfillProcessor<'a, 'tcx>
source§fn needs_process_obligation(&self, pending_obligation: &Self::Obligation) -> bool
fn needs_process_obligation(&self, pending_obligation: &Self::Obligation) -> bool
Identifies whether a predicate obligation needs processing.
This is always inlined, despite its size, because it has a single callsite and it is called very frequently.
source§fn process_obligation(
&mut self,
pending_obligation: &mut PendingPredicateObligation<'tcx>
) -> ProcessResult<PendingPredicateObligation<'tcx>, FulfillmentErrorCode<'tcx>>
fn process_obligation(
&mut self,
pending_obligation: &mut PendingPredicateObligation<'tcx>
) -> ProcessResult<PendingPredicateObligation<'tcx>, FulfillmentErrorCode<'tcx>>
Processes a predicate obligation and returns either:
Changed(v)
if the predicate is true, presuming thatv
are also trueUnchanged
if we don’t have enough info to be sureError(e)
if the predicate does not hold
This is called much less often than needs_process_obligation
, so we
never inline it.
type Obligation = PendingPredicateObligation<'tcx>
type Error = FulfillmentErrorCode<'tcx>
type OUT = Outcome<PendingPredicateObligation<'tcx>, FulfillmentErrorCode<'tcx>>
source§fn process_backedge<'c, I>(
&mut self,
cycle: I,
_marker: PhantomData<&'c PendingPredicateObligation<'tcx>>
) -> Result<(), FulfillmentErrorCode<'tcx>>where
I: Clone + Iterator<Item = &'c PendingPredicateObligation<'tcx>>,
fn process_backedge<'c, I>(
&mut self,
cycle: I,
_marker: PhantomData<&'c PendingPredicateObligation<'tcx>>
) -> Result<(), FulfillmentErrorCode<'tcx>>where
I: Clone + Iterator<Item = &'c PendingPredicateObligation<'tcx>>,
As we do the cycle check, we invoke this callback when we
encounter an actual cycle.
cycle
is an iterator that starts
at the start of the cycle in the stack and walks toward the
top. Read moreAuto Trait Implementations§
impl<'a, 'tcx> !RefUnwindSafe for FulfillProcessor<'a, 'tcx>
impl<'a, 'tcx> !Send for FulfillProcessor<'a, 'tcx>
impl<'a, 'tcx> !Sync for FulfillProcessor<'a, 'tcx>
impl<'a, 'tcx> Unpin for FulfillProcessor<'a, 'tcx>where
'tcx: 'a,
impl<'a, 'tcx> !UnwindSafe for FulfillProcessor<'a, 'tcx>
Blanket Implementations§
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: 160 bytes