]> git.lizzy.rs Git - rust.git/blob - src/tools/miri/tests/pass/dst-struct.rs
Rollup merge of #84022 - Aaron1011:remove-derive-res-fallback, r=petrochenkov
[rust.git] / src / tools / miri / tests / pass / dst-struct.rs
1 #![feature(box_syntax)]
2
3 struct Fat<T: ?Sized> {
4     f1: isize,
5     f2: &'static str,
6     ptr: T,
7 }
8
9 // x is a fat pointer
10 fn foo(x: &Fat<[isize]>) {
11     let y = &x.ptr;
12     assert_eq!(x.ptr.len(), 3);
13     assert_eq!(y[0], 1);
14     assert_eq!(x.ptr[1], 2);
15     assert_eq!(x.f1, 5);
16     assert_eq!(x.f2, "some str");
17 }
18
19 fn foo2<T: ToBar>(x: &Fat<[T]>) {
20     let y = &x.ptr;
21     let bar = Bar;
22     assert_eq!(x.ptr.len(), 3);
23     assert_eq!(y[0].to_bar(), bar);
24     assert_eq!(x.ptr[1].to_bar(), bar);
25     assert_eq!(x.f1, 5);
26     assert_eq!(x.f2, "some str");
27 }
28
29 fn foo3(x: &Fat<Fat<[isize]>>) {
30     let y = &x.ptr.ptr;
31     assert_eq!(x.f1, 5);
32     assert_eq!(x.f2, "some str");
33     assert_eq!(x.ptr.f1, 8);
34     assert_eq!(x.ptr.f2, "deep str");
35     assert_eq!(x.ptr.ptr.len(), 3);
36     assert_eq!(y[0], 1);
37     assert_eq!(x.ptr.ptr[1], 2);
38 }
39
40 #[derive(Copy, Clone, PartialEq, Eq, Debug)]
41 struct Bar;
42
43 trait ToBar {
44     fn to_bar(&self) -> Bar;
45 }
46
47 impl ToBar for Bar {
48     fn to_bar(&self) -> Bar {
49         *self
50     }
51 }
52
53 pub fn main() {
54     // With a vec of ints.
55     let f1: Fat<[isize; 3]> = Fat { f1: 5, f2: "some str", ptr: [1, 2, 3] };
56     foo(&f1);
57     let f2: &Fat<[isize; 3]> = &f1;
58     foo(f2);
59     let f3: &Fat<[isize]> = f2;
60     foo(f3);
61     let f4: &Fat<[isize]> = &f1;
62     foo(f4);
63     let f5: &Fat<[isize]> = &Fat { f1: 5, f2: "some str", ptr: [1, 2, 3] };
64     foo(f5);
65
66     // With a vec of Bars.
67     let bar = Bar;
68     let f1 = Fat { f1: 5, f2: "some str", ptr: [bar, bar, bar] };
69     foo2(&f1);
70     let f2 = &f1;
71     foo2(f2);
72     let f3: &Fat<[Bar]> = f2;
73     foo2(f3);
74     let f4: &Fat<[Bar]> = &f1;
75     foo2(f4);
76     let f5: &Fat<[Bar]> = &Fat { f1: 5, f2: "some str", ptr: [bar, bar, bar] };
77     foo2(f5);
78
79     // Assignment.
80     let f5: &mut Fat<[isize]> = &mut Fat { f1: 5, f2: "some str", ptr: [1, 2, 3] };
81     f5.ptr[1] = 34;
82     assert_eq!(f5.ptr[0], 1);
83     assert_eq!(f5.ptr[1], 34);
84     assert_eq!(f5.ptr[2], 3);
85
86     // Zero size vec.
87     let f5: &Fat<[isize]> = &Fat { f1: 5, f2: "some str", ptr: [] };
88     assert!(f5.ptr.is_empty());
89     let f5: &Fat<[Bar]> = &Fat { f1: 5, f2: "some str", ptr: [] };
90     assert!(f5.ptr.is_empty());
91
92     // Deeply nested.
93     let f1 = Fat { f1: 5, f2: "some str", ptr: Fat { f1: 8, f2: "deep str", ptr: [1, 2, 3] } };
94     foo3(&f1);
95     let f2 = &f1;
96     foo3(f2);
97     let f3: &Fat<Fat<[isize]>> = f2;
98     foo3(f3);
99     let f4: &Fat<Fat<[isize]>> = &f1;
100     foo3(f4);
101     let f5: &Fat<Fat<[isize]>> =
102         &Fat { f1: 5, f2: "some str", ptr: Fat { f1: 8, f2: "deep str", ptr: [1, 2, 3] } };
103     foo3(f5);
104
105     // Box.
106     let f1 = Box::new([1, 2, 3]);
107     assert_eq!((*f1)[1], 2);
108     let f2: Box<[isize]> = f1;
109     assert_eq!((*f2)[1], 2);
110
111     // Nested Box.
112     let f1: Box<Fat<[isize; 3]>> = box Fat { f1: 5, f2: "some str", ptr: [1, 2, 3] };
113     foo(&*f1);
114     let f2: Box<Fat<[isize]>> = f1;
115     foo(&*f2);
116
117     let f3: Box<Fat<[isize]>> =
118         Box::<Fat<[_; 3]>>::new(Fat { f1: 5, f2: "some str", ptr: [1, 2, 3] });
119     foo(&*f3);
120     let f4: Box<Fat<[isize]>> = box Fat { f1: 5, f2: "some str", ptr: [1, 2, 3] };
121     foo(&*f4);
122 }