Struct rustc_infer::infer::equate::Equate
source · pub struct Equate<'combine, 'infcx, 'tcx> {
fields: &'combine mut CombineFields<'infcx, 'tcx>,
a_is_expected: bool,
}
Expand description
Ensures a
is made equal to b
. Returns a
on success.
Fields§
§fields: &'combine mut CombineFields<'infcx, 'tcx>
§a_is_expected: bool
Implementations§
Trait Implementations§
source§impl<'tcx> ObligationEmittingRelation<'tcx> for Equate<'_, '_, 'tcx>
impl<'tcx> ObligationEmittingRelation<'tcx> for Equate<'_, '_, 'tcx>
source§fn register_predicates(
&mut self,
obligations: impl IntoIterator<Item: ToPredicate<'tcx>>
)
fn register_predicates( &mut self, obligations: impl IntoIterator<Item: ToPredicate<'tcx>> )
Register predicates that must hold in order for this relation to hold. Uses
a default obligation cause,
ObligationEmittingRelation::register_obligations
should
be used if control over the obligation causes is required.source§fn register_obligations(&mut self, obligations: PredicateObligations<'tcx>)
fn register_obligations(&mut self, obligations: PredicateObligations<'tcx>)
Register obligations that must hold in order for this relation to hold
source§fn alias_relate_direction(&self) -> AliasRelationDirection
fn alias_relate_direction(&self) -> AliasRelationDirection
Relation direction emitted for
AliasRelate
predicates, corresponding to the direction
of the relation.source§fn register_type_relate_obligation(&mut self, a: Ty<'tcx>, b: Ty<'tcx>)
fn register_type_relate_obligation(&mut self, a: Ty<'tcx>, b: Ty<'tcx>)
Register an obligation that both types must be related to each other according to
the
ty::AliasRelationDirection
given by ObligationEmittingRelation::alias_relate_direction
source§impl<'tcx> TypeRelation<'tcx> for Equate<'_, '_, 'tcx>
impl<'tcx> TypeRelation<'tcx> for Equate<'_, '_, 'tcx>
fn tcx(&self) -> TyCtxt<'tcx>
fn param_env(&self) -> ParamEnv<'tcx>
source§fn a_is_expected(&self) -> bool
fn a_is_expected(&self) -> bool
Returns
true
if the value a
is the “expected” type in the
relation. Just affects error messages.source§fn relate_item_args(
&mut self,
_item_def_id: DefId,
a_arg: GenericArgsRef<'tcx>,
b_arg: GenericArgsRef<'tcx>
) -> RelateResult<'tcx, GenericArgsRef<'tcx>>
fn relate_item_args( &mut self, _item_def_id: DefId, a_arg: GenericArgsRef<'tcx>, b_arg: GenericArgsRef<'tcx> ) -> RelateResult<'tcx, GenericArgsRef<'tcx>>
Relate the two args for the given item. The default
is to look up the variance for the item and proceed
accordingly.
source§fn relate_with_variance<T: Relate<'tcx>>(
&mut self,
_: Variance,
_info: VarianceDiagInfo<'tcx>,
a: T,
b: T
) -> RelateResult<'tcx, T>
fn relate_with_variance<T: Relate<'tcx>>( &mut self, _: Variance, _info: VarianceDiagInfo<'tcx>, a: T, b: T ) -> RelateResult<'tcx, T>
Switch variance for the purpose of relating
a
and b
.fn tys(&mut self, a: Ty<'tcx>, b: Ty<'tcx>) -> RelateResult<'tcx, Ty<'tcx>>
fn regions( &mut self, a: Region<'tcx>, b: Region<'tcx> ) -> RelateResult<'tcx, Region<'tcx>>
fn consts( &mut self, a: Const<'tcx>, b: Const<'tcx> ) -> RelateResult<'tcx, Const<'tcx>>
fn binders<T>( &mut self, a: Binder<'tcx, T>, b: Binder<'tcx, T> ) -> RelateResult<'tcx, Binder<'tcx, T>>where T: Relate<'tcx>,
fn with_cause<F, R>(&mut self, _cause: Cause, f: F) -> Rwhere F: FnOnce(&mut Self) -> R,
Auto Trait Implementations§
impl<'combine, 'infcx, 'tcx> !RefUnwindSafe for Equate<'combine, 'infcx, 'tcx>
impl<'combine, 'infcx, 'tcx> !Send for Equate<'combine, 'infcx, 'tcx>
impl<'combine, 'infcx, 'tcx> !Sync for Equate<'combine, 'infcx, 'tcx>
impl<'combine, 'infcx, 'tcx> Unpin for Equate<'combine, 'infcx, 'tcx>
impl<'combine, 'infcx, 'tcx> !UnwindSafe for Equate<'combine, 'infcx, '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
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: 16 bytes