File: instantiate-canonical-occurs-check-failure.rs

package info (click to toggle)
rustc 1.85.0%2Bdfsg2-3
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 893,176 kB
  • sloc: xml: 158,127; python: 35,830; javascript: 19,497; cpp: 19,002; sh: 17,245; ansic: 13,127; asm: 4,376; makefile: 1,051; lisp: 29; perl: 29; ruby: 19; sql: 11
file content (29 lines) | stat: -rw-r--r-- 1,018 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
//@ compile-flags: -Znext-solver
//@ check-pass

// With #119106 generalization now results in `AliasRelate` if the generalized
// alias contains an inference variable which is not nameable.
//
// We previously proved alias-relate after canonicalization, which does not keep track
// of universe indices, so all inference vars were nameable inside of `AliasRelate`.
//
// If we now have a rigid projection containing an unnameable inference variable,
// we should emit an alias-relate obligation, which constrains the type of `x` to
// an alias. This caused us to emit yet another equivalent alias-relate obligation
// when trying to instantiate the query result, resulting in overflow.
trait Trait<'a> {
    type Assoc: Default;
}

fn takes_alias<'a, T: Trait<'a>>(_: <T as Trait<'a>>::Assoc) {}

fn foo<T: for<'a> Trait<'a>>() {
    let x = Default::default();

    let _incr_universe: for<'a, 'b> fn(&'a (), &'b ()) =
        (|&(), &()| ()) as for<'a> fn(&'a (), &'a ());

    takes_alias::<T>(x);
}

fn main() {}