1
Fork 0

get_ambient_variance to inherent method

This commit is contained in:
lcnr 2024-12-18 13:03:15 +01:00
parent 37e74596c0
commit 5f90b15f09
2 changed files with 24 additions and 24 deletions

View file

@ -651,7 +651,7 @@ impl<'a, 'b, 'tcx> TypeVerifier<'a, 'b, 'tcx> {
if let Err(terr) = self.typeck.relate_types(
ty,
self.get_ambient_variance(context),
context.ambient_variance(),
fty,
location.to_locations(),
ConstraintCategory::Boring,
@ -685,7 +685,7 @@ impl<'a, 'b, 'tcx> TypeVerifier<'a, 'b, 'tcx> {
self.typeck
.relate_types(
ty,
self.get_ambient_variance(context),
context.ambient_variance(),
base.ty,
location.to_locations(),
ConstraintCategory::TypeAnnotation,
@ -700,21 +700,6 @@ impl<'a, 'b, 'tcx> TypeVerifier<'a, 'b, 'tcx> {
Ty::new_misc_error(self.tcx())
}
fn get_ambient_variance(&self, context: PlaceContext) -> ty::Variance {
use rustc_middle::mir::visit::NonMutatingUseContext::*;
use rustc_middle::mir::visit::NonUseContext::*;
match context {
PlaceContext::MutatingUse(_) => ty::Invariant,
PlaceContext::NonUse(StorageDead | StorageLive | VarDebugInfo) => ty::Invariant,
PlaceContext::NonMutatingUse(
Inspect | Copy | Move | PlaceMention | SharedBorrow | FakeBorrow | RawBorrow
| Projection,
) => ty::Covariant,
PlaceContext::NonUse(AscribeUserTy(variance)) => variance,
}
}
fn field_ty(
&mut self,
parent: &dyn fmt::Debug,