File: closure-signature-inference-2.rs

package info (click to toggle)
rustc 1.85.0%2Bdfsg2-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, 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 (21 lines) | stat: -rw-r--r-- 663 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
//@ 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!
}