Rollup merge of #100490 - lcnr:wf-consts, r=jackh726
wf: correctly `shallow_resolve` consts `shallow_resolve` on `InferConst` is always a noop. this is mostly irrelevant as inference vars should already be resolved at most - if not all - call sites. Haven't actually looked too deeply into whether this was a problem.
This commit is contained in:
commit
aafaec38bb
@ -31,9 +31,9 @@ pub fn obligations<'a, 'tcx>(
|
||||
if resolved_ty == ty {
|
||||
// No progress, bail out to prevent "livelock".
|
||||
return None;
|
||||
} else {
|
||||
resolved_ty
|
||||
}
|
||||
|
||||
resolved_ty
|
||||
}
|
||||
_ => ty,
|
||||
}
|
||||
@ -41,16 +41,14 @@ pub fn obligations<'a, 'tcx>(
|
||||
}
|
||||
GenericArgKind::Const(ct) => {
|
||||
match ct.kind() {
|
||||
ty::ConstKind::Infer(infer) => {
|
||||
let resolved = infcx.shallow_resolve(infer);
|
||||
if resolved == infer {
|
||||
ty::ConstKind::Infer(_) => {
|
||||
let resolved = infcx.shallow_resolve(ct);
|
||||
if resolved == ct {
|
||||
// No progress.
|
||||
return None;
|
||||
} else {
|
||||
resolved
|
||||
}
|
||||
|
||||
infcx
|
||||
.tcx
|
||||
.mk_const(ty::ConstS { kind: ty::ConstKind::Infer(resolved), ty: ct.ty() })
|
||||
}
|
||||
_ => ct,
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user