summaryrefslogtreecommitdiffstats
path: root/src/test/ui/mismatched_types/closure-arg-count.rs
blob: e817631ad5d79bb095b63fc3c81285f3f5b4cdeb (plain)
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
30
31
32
33
34
35
36
37
38
39
40
41
42
43
#![feature(unboxed_closures)]

fn f<F: Fn<usize>>(_: F) {}
fn main() {
    [1, 2, 3].sort_by(|| panic!());
    //~^ ERROR closure is expected to take
    [1, 2, 3].sort_by(|tuple| panic!());
    //~^ ERROR closure is expected to take
    [1, 2, 3].sort_by(|(tuple, tuple2)| panic!());
    //~^ ERROR closure is expected to take
    [1, 2, 3].sort_by(|(tuple, tuple2): (usize, _)| panic!());
    //~^ ERROR closure is expected to take
    f(|| panic!());
    //~^ ERROR closure is expected to take
    f(  move    || panic!());
    //~^ ERROR closure is expected to take

    let _it = vec![1, 2, 3].into_iter().enumerate().map(|i, x| i);
    //~^ ERROR closure is expected to take
    let _it = vec![1, 2, 3].into_iter().enumerate().map(|i: usize, x| i);
    //~^ ERROR closure is expected to take
    let _it = vec![1, 2, 3].into_iter().enumerate().map(|i, x, y| i);
    //~^ ERROR closure is expected to take
    let _it = vec![1, 2, 3].into_iter().enumerate().map(foo);
    //~^ ERROR function is expected to take
    let bar = |i, x, y| i;
    let _it = vec![1, 2, 3].into_iter().enumerate().map(bar);
    //~^ ERROR closure is expected to take
    let _it = vec![1, 2, 3].into_iter().enumerate().map(qux);
    //~^ ERROR function is expected to take

    let _it = vec![1, 2, 3].into_iter().map(usize::checked_add);
    //~^ ERROR function is expected to take

    call(Foo);
    //~^ ERROR function is expected to take
}

fn foo() {}
fn qux(x: usize, y: usize) {}

fn call<F, R>(_: F) where F: FnOnce() -> R {}
struct Foo(u8);