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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
#[cfg(all(feature = "std", feature = "specialization"))]
macro_rules! default {
($($fn:tt)*) => { default $($fn)* };
}
#[cfg(all(feature = "std", not(feature = "specialization")))]
macro_rules! default {
($($fn:tt)*) => { $($fn)* };
}
#[macro_export]
macro_rules! project_struct {
($struct:ident: $ty:path => $field:tt) => {
#[allow(unused_unsafe)]
(unsafe {
&mut *($struct as &mut MaybeUninit<$ty>)
.as_mut_ptr()
.cast::<u8>()
.add($crate::offset_of!($ty, $field))
.cast()
})
};
($struct:ident: $struct_ty:path => $field:tt: $field_ty:path) => {
#[allow(unused_unsafe)]
(unsafe {
&mut *($struct as &mut MaybeUninit<$struct_ty>)
.as_mut_ptr()
.cast::<u8>()
.add($crate::offset_of!($struct_ty, $field))
.cast::<MaybeUninit<$field_ty>>()
})
};
}
#[macro_export]
macro_rules! project_tuple {
($tuple:ident: $ty:ty => $index:tt) => {
(unsafe {
&mut *($tuple as &mut MaybeUninit<$ty>)
.as_mut_ptr()
.cast::<u8>()
.add(memoffset::offset_of_tuple!($ty, $index))
.cast()
})
};
($tuple:ident: $tuple_ty:ty => $index:tt: $index_ty:path) => {
(unsafe {
&mut *($tuple as &mut MaybeUninit<$tuple_ty>)
.as_mut_ptr()
.cast::<u8>()
.add(memoffset::offset_of_tuple!($tuple_ty, $index))
.cast::<MaybeUninit<$index_ty>>()
})
};
}
macro_rules! resolve_struct {
($out:ident = |$pos:ident, $resolver:ident| -> $out_ty:path { $($field:ident: $field_expr:expr),* }) => {
resolve_struct!($out = |$pos, $resolver| -> $out_ty { $($field: $field_expr,)* });
};
($out:ident = |$pos:ident, $resolver:ident| -> $out_ty:path { $($field:ident: $field_expr:expr,)* }) => {
$(
unsafe {
let field_offset = memoffset::offset_of!($out_ty, $field);
$field_expr.resolve(
$pos + field_offset,
$resolver.$field,
&mut *$out.as_mut_ptr().cast::<u8>().add(field_offset).cast()
);
}
)*
};
}