about summary refs log tree commit diff
path: root/src/tools/clippy/tests/ui/init_numbered_fields.rs
blob: 8cb34705b4f67d13982c12031e7a48c4f3526b13 (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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
#![warn(clippy::init_numbered_fields)]

#[derive(Default)]
struct TupleStruct(u32, u32, u8);

// This shouldn't lint because it's in a macro
macro_rules! tuple_struct_init {
    () => {
        TupleStruct { 0: 0, 1: 1, 2: 2 }
    };
}

fn main() {
    let tuple_struct = TupleStruct::default();

    // This should lint
    let _ = TupleStruct {
        0: 1u32,
        1: 42,
        2: 23u8,
    };

    // This should also lint and order the fields correctly
    let _ = TupleStruct {
        0: 1u32,
        2: 2u8,
        1: 3u32,
    };

    // Ok because of default initializer
    let _ = TupleStruct { 0: 42, ..tuple_struct };

    let _ = TupleStruct {
        1: 23,
        ..TupleStruct::default()
    };

    // Ok because it's in macro
    let _ = tuple_struct_init!();

    type Alias = TupleStruct;

    // Aliases can't be tuple constructed #8638
    let _ = Alias { 0: 0, 1: 1, 2: 2 };

    // Issue #12367
    struct TupleStructVec(Vec<usize>);

    let _ = TupleStructVec { 0: vec![0, 1, 2, 3] };

    {
        struct S(i32, i32);
        let mut iter = [1i32, 1i32].into_iter();
        let _ = S {
            1: iter.next().unwrap(),
            0: iter.next().unwrap(),
        };
    }
}