about summary refs log tree commit diff
path: root/tests/ui/impl-trait/non-defining-uses/as-projection-term.rs
blob: 19f983bab700ffb97de18feff10532c094d0b5d2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
//@ revisions: current next
//@[next] compile-flags: -Znext-solver
//@ ignore-compare-mode-next-solver (explicit revisions)
//@ check-pass

fn prove_proj<R>(_: impl FnOnce() -> R) {}
fn recur<'a>() -> impl Sized + 'a {
    // The closure has the signature `fn() -> opaque<'1>`. `prove_proj`
    // requires us to prove `<closure as FnOnce<()>>::Output = opaque<'2>`.
    // The old solver uses `replace_opaque_types_with_infer` during normalization
    // to replace `opaque<'2>` with its hidden type. If that hidden type is still an
    // inference variable at this point, we unify it with `opaque<'1>` and
    // end up ignoring that defining use as the hidden type is equal to its key.
    prove_proj(|| recur());
}

fn main() {}