File: closure-signature-inference-2.rs

package info (click to toggle)
rustc 1.86.0%2Bdfsg1-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental, forky, sid
  • size: 913,560 kB
  • sloc: xml: 158,127; python: 35,921; javascript: 19,689; sh: 19,600; cpp: 18,906; ansic: 13,124; asm: 4,376; makefile: 708; perl: 29; lisp: 29; ruby: 19; sql: 11
file content (21 lines) | stat: -rw-r--r-- 663 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
//@ compile-flags: -Znext-solver
//@ check-pass

fn map<T: Default, U, F: FnOnce(T) -> U>(f: F) {
    f(T::default());
}

fn main() {
    map::<i32, _ /* ?U */, _ /* ?F */>(|x| x.to_string());
    // PREVIOUSLY when confirming the `map` call, we register:
    //
    // (1.) ?F: FnOnce<(i32,)>
    // (2.) <?F as FnOnce<(i32,)>>::Output projects-to ?U
    //
    // While (1.) is ambiguous, (2.) immediately gets processed
    // and we infer `?U := <?F as FnOnce<(i32,)>>::Output`.
    //
    // Thus, the only pending obligation that remains is (1.).
    // Since it is a trait obligation, we don't use it to deduce
    // the closure signature, and we fail!
}