summaryrefslogtreecommitdiffstats
path: root/src/test/ui/suggestions/args-instead-of-tuple.fixed
blob: 66e53f9ce2c80bef49c642f16571fc521fb0f458 (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
// Test suggesting tuples where bare arguments may have been passed
// See issue #86481 for details.

// run-rustfix

fn main() {
    let _: Result<(i32, i8), ()> = Ok((1, 2));
    //~^ ERROR this enum variant takes 1 argument but 2 arguments were supplied
    let _: Option<(i32, i8, &'static str)> = Some((1, 2, "hi"));
    //~^ ERROR this enum variant takes 1 argument but 3 arguments were supplied
    let _: Option<()> = Some(());
    //~^ ERROR this enum variant takes 1 argument but 0 arguments were supplied

    let _: Option<(i32,)> = Some((3,));
    //~^ ERROR mismatched types

    let _: Option<(i32,)> = Some((3,));
    //~^ ERROR mismatched types

    two_ints((1, 2)); //~ ERROR this function takes 1 argument

    with_generic((3, 4)); //~ ERROR this function takes 1 argument
}

fn two_ints(_: (i32, i32)) {
}

fn with_generic<T: Copy + Send>((a, b): (i32, T)) {
    if false {
        // test generics/bound handling
        with_generic((a, b)); //~ ERROR this function takes 1 argument
    }
}