Struct rustc_infer::infer::relate::nll::TypeRelating
source · pub struct TypeRelating<'me, 'tcx, D>where
D: TypeRelatingDelegate<'tcx>,{
infcx: &'me InferCtxt<'tcx>,
delegate: D,
ambient_variance: Variance,
ambient_variance_info: VarianceDiagInfo<'tcx>,
}Fields§
§infcx: &'me InferCtxt<'tcx>§delegate: DCallback to use when we deduce an outlives relationship.
ambient_variance: VarianceHow are we relating a and b?
- Covariant means
a <: b. - Contravariant means
b <: a. - Invariant means
a == b. - Bivariant means that it doesn’t matter.
ambient_variance_info: VarianceDiagInfo<'tcx>Implementations§
source§impl<'me, 'tcx, D> TypeRelating<'me, 'tcx, D>where
D: TypeRelatingDelegate<'tcx>,
impl<'me, 'tcx, D> TypeRelating<'me, 'tcx, D>where
D: TypeRelatingDelegate<'tcx>,
pub fn new( infcx: &'me InferCtxt<'tcx>, delegate: D, ambient_variance: Variance ) -> Self
fn ambient_covariance(&self) -> bool
fn ambient_contravariance(&self) -> bool
sourcefn push_outlives(
&mut self,
sup: Region<'tcx>,
sub: Region<'tcx>,
info: VarianceDiagInfo<'tcx>
)
fn push_outlives( &mut self, sup: Region<'tcx>, sub: Region<'tcx>, info: VarianceDiagInfo<'tcx> )
Push a new outlives requirement into our output set of constraints.
fn relate_opaques(&mut self, a: Ty<'tcx>, b: Ty<'tcx>) -> RelateResult<'tcx, ()>
fn enter_forall<T, U>( &mut self, binder: Binder<'tcx, T>, f: impl FnOnce(&mut Self, T) -> U ) -> U
fn instantiate_binder_with_existentials<T>( &mut self, binder: Binder<'tcx, T> ) -> T
Trait Implementations§
source§impl<'tcx, D> ObligationEmittingRelation<'tcx> for TypeRelating<'_, 'tcx, D>where
D: TypeRelatingDelegate<'tcx>,
impl<'tcx, D> ObligationEmittingRelation<'tcx> for TypeRelating<'_, 'tcx, D>where
D: TypeRelatingDelegate<'tcx>,
fn span(&self) -> Span
fn param_env(&self) -> ParamEnv<'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_directionsource§impl<'tcx, D> TypeRelation<'tcx> for TypeRelating<'_, 'tcx, D>where
D: TypeRelatingDelegate<'tcx>,
impl<'tcx, D> TypeRelation<'tcx> for TypeRelating<'_, 'tcx, D>where
D: TypeRelatingDelegate<'tcx>,
fn tcx(&self) -> TyCtxt<'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_with_variance<T: Relate<'tcx>>(
&mut self,
variance: Variance,
info: VarianceDiagInfo<'tcx>,
a: T,
b: T
) -> RelateResult<'tcx, T>
fn relate_with_variance<T: Relate<'tcx>>( &mut self, variance: 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) -> R
source§fn relate<T>(&mut self, a: T, b: T) -> Result<T, TypeError<'tcx>>where
T: Relate<'tcx>,
fn relate<T>(&mut self, a: T, b: T) -> Result<T, TypeError<'tcx>>where
T: Relate<'tcx>,
Generic relation routine suitable for most anything.
source§fn relate_item_args(
&mut self,
item_def_id: DefId,
a_arg: &'tcx List<GenericArg<'tcx>>,
b_arg: &'tcx List<GenericArg<'tcx>>
) -> Result<&'tcx List<GenericArg<'tcx>>, TypeError<'tcx>>
fn relate_item_args( &mut self, item_def_id: DefId, a_arg: &'tcx List<GenericArg<'tcx>>, b_arg: &'tcx List<GenericArg<'tcx>> ) -> Result<&'tcx List<GenericArg<'tcx>>, TypeError<'tcx>>
Relate the two args for the given item. The default
is to look up the variance for the item and proceed
accordingly.
Auto Trait Implementations§
impl<'me, 'tcx, D> !DynSend for TypeRelating<'me, 'tcx, D>
impl<'me, 'tcx, D> !DynSync for TypeRelating<'me, 'tcx, D>
impl<'me, 'tcx, D> !RefUnwindSafe for TypeRelating<'me, 'tcx, D>
impl<'me, 'tcx, D> !Send for TypeRelating<'me, 'tcx, D>
impl<'me, 'tcx, D> !Sync for TypeRelating<'me, 'tcx, D>
impl<'me, 'tcx, D> Unpin for TypeRelating<'me, 'tcx, D>where
D: Unpin,
impl<'me, 'tcx, D> !UnwindSafe for TypeRelating<'me, 'tcx, D>
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
§impl<T> Filterable for T
impl<T> Filterable for T
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<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
§impl<T> Pointable for T
impl<T> Pointable 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_error: &CycleError, _guar: ErrorGuaranteed ) -> 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<'a, T> Captures<'a> for Twhere
T: ?Sized,
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.