]> git.lizzy.rs Git - rust.git/blob - src/test/ui/dynamically-sized-types/dst-tuple.rs
Auto merge of #89285 - jackh726:issue-88862, r=nikomatsakis
[rust.git] / src / test / ui / dynamically-sized-types / dst-tuple.rs
1 // run-pass
2 #![allow(type_alias_bounds)]
3
4 #![feature(unsized_tuple_coercion)]
5
6 type Fat<T: ?Sized> = (isize, &'static str, T);
7
8 // x is a fat pointer
9 fn foo(x: &Fat<[isize]>) {
10     let y = &x.2;
11     assert_eq!(x.2.len(), 3);
12     assert_eq!(y[0], 1);
13     assert_eq!(x.2[1], 2);
14     assert_eq!(x.0, 5);
15     assert_eq!(x.1, "some str");
16 }
17
18 fn foo2<T:ToBar>(x: &Fat<[T]>) {
19     let y = &x.2;
20     let bar = Bar;
21     assert_eq!(x.2.len(), 3);
22     assert_eq!(y[0].to_bar(), bar);
23     assert_eq!(x.2[1].to_bar(), bar);
24     assert_eq!(x.0, 5);
25     assert_eq!(x.1, "some str");
26 }
27
28 fn foo3(x: &Fat<Fat<[isize]>>) {
29     let y = &(x.2).2;
30     assert_eq!(x.0, 5);
31     assert_eq!(x.1, "some str");
32     assert_eq!((x.2).0, 8);
33     assert_eq!((x.2).1, "deep str");
34     assert_eq!((x.2).2.len(), 3);
35     assert_eq!(y[0], 1);
36     assert_eq!((x.2).2[1], 2);
37 }
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 = (5, "some str", [1, 2, 3]);
56     foo(&f1);
57     let f2 = &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]> = &(5, "some str", [1, 2, 3]);
64     foo(f5);
65
66     // With a vec of Bars.
67     let bar = Bar;
68     let f1 = (5, "some str", [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]> = &(5, "some str", [bar, bar, bar]);
77     foo2(f5);
78
79     // Assignment.
80     let f5: &mut Fat<[isize]> = &mut (5, "some str", [1, 2, 3]);
81     f5.2[1] = 34;
82     assert_eq!(f5.2[0], 1);
83     assert_eq!(f5.2[1], 34);
84     assert_eq!(f5.2[2], 3);
85
86     // Zero size vec.
87     let f5: &Fat<[isize]> = &(5, "some str", []);
88     assert!(f5.2.is_empty());
89     let f5: &Fat<[Bar]> = &(5, "some str", []);
90     assert!(f5.2.is_empty());
91
92     // Deeply nested.
93     let f1 = (5, "some str", (8, "deep str", [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]>> = &(5, "some str", (8, "deep str", [1, 2, 3]));
102     foo3(f5);
103
104     // Box.
105     let f1 = Box::new([1, 2, 3]);
106     assert_eq!((*f1)[1], 2);
107     let f2: Box<[isize]> = f1;
108     assert_eq!((*f2)[1], 2);
109
110     // Nested Box.
111     let f1 : Box<Fat<[isize; 3]>> = Box::new((5, "some str", [1, 2, 3]));
112     foo(&*f1);
113     let f2 : Box<Fat<[isize]>> = f1;
114     foo(&*f2);
115
116     let f3 : Box<Fat<[isize]>> =
117         Box::<Fat<[_; 3]>>::new((5, "some str", [1, 2, 3]));
118     foo(&*f3);
119 }