Rollup merge of #110272 - Ezrashaw:fix-unconned-lt-in-implbounds, r=aliemjay
fix: skip implied bounds if unconstrained lifetime exists Fixes #110161 r? ````@aliemjay````
This commit is contained in:
commit
52d23c9253
3 changed files with 50 additions and 1 deletions
|
@ -55,7 +55,18 @@ impl<'a, 'tcx: 'a> InferCtxtExt<'a, 'tcx> for InferCtxt<'tcx> {
|
||||||
) -> Vec<OutlivesBound<'tcx>> {
|
) -> Vec<OutlivesBound<'tcx>> {
|
||||||
let ty = self.resolve_vars_if_possible(ty);
|
let ty = self.resolve_vars_if_possible(ty);
|
||||||
let ty = OpportunisticRegionResolver::new(self).fold_ty(ty);
|
let ty = OpportunisticRegionResolver::new(self).fold_ty(ty);
|
||||||
assert!(!ty.needs_infer());
|
|
||||||
|
// We do not expect existential variables in implied bounds.
|
||||||
|
// We may however encounter unconstrained lifetime variables in invalid
|
||||||
|
// code. See #110161 for context.
|
||||||
|
assert!(!ty.has_non_region_infer());
|
||||||
|
if ty.needs_infer() {
|
||||||
|
self.tcx.sess.delay_span_bug(
|
||||||
|
self.tcx.def_span(body_id),
|
||||||
|
"skipped implied_outlives_bounds due to unconstrained lifetimes",
|
||||||
|
);
|
||||||
|
return vec![];
|
||||||
|
}
|
||||||
|
|
||||||
let span = self.tcx.def_span(body_id);
|
let span = self.tcx.def_span(body_id);
|
||||||
let result = param_env
|
let result = param_env
|
||||||
|
|
26
tests/ui/implied-bounds/issue-110161.rs
Normal file
26
tests/ui/implied-bounds/issue-110161.rs
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
// ICE regression relating to unconstrained lifetimes in implied
|
||||||
|
// bounds. See #110161.
|
||||||
|
|
||||||
|
// compile-flags: --crate-type=lib
|
||||||
|
|
||||||
|
trait LtTrait {
|
||||||
|
type Ty;
|
||||||
|
}
|
||||||
|
|
||||||
|
// erroneous `Ty` impl
|
||||||
|
impl LtTrait for () {
|
||||||
|
//~^ ERROR not all trait items implemented, missing: `Ty` [E0046]
|
||||||
|
}
|
||||||
|
|
||||||
|
// `'lt` is not constrained by the erroneous `Ty`
|
||||||
|
impl<'lt, T> LtTrait for Box<T>
|
||||||
|
where
|
||||||
|
T: LtTrait<Ty = &'lt ()>,
|
||||||
|
{
|
||||||
|
type Ty = &'lt ();
|
||||||
|
}
|
||||||
|
|
||||||
|
// unconstrained lifetime appears in implied bounds
|
||||||
|
fn test(_: <Box<()> as LtTrait>::Ty) {}
|
||||||
|
|
||||||
|
fn test2<'x>(_: &'x <Box<()> as LtTrait>::Ty) {}
|
12
tests/ui/implied-bounds/issue-110161.stderr
Normal file
12
tests/ui/implied-bounds/issue-110161.stderr
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
error[E0046]: not all trait items implemented, missing: `Ty`
|
||||||
|
--> $DIR/issue-110161.rs:11:1
|
||||||
|
|
|
||||||
|
LL | type Ty;
|
||||||
|
| ------- `Ty` from trait
|
||||||
|
...
|
||||||
|
LL | impl LtTrait for () {
|
||||||
|
| ^^^^^^^^^^^^^^^^^^^ missing `Ty` in implementation
|
||||||
|
|
||||||
|
error: aborting due to previous error
|
||||||
|
|
||||||
|
For more information about this error, try `rustc --explain E0046`.
|
Loading…
Add table
Add a link
Reference in a new issue