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
macro_rules! cast_slice_u8_to_typed_slice {
($name: ident, $typ: ident) => {
unsafe { &*($name as *const [u8] as *const $typ) }
};
}
macro_rules! slice_reexport_asref {
($name: ident) => {
impl AsRef<[u8]> for $name {
fn as_ref(&self) -> &[u8] {
&self.0.as_ref()
}
}
};
}
macro_rules! slice_owned_mapping {
($ty: ident, $slice: ident) => {
#[cfg(feature = "owned")]
impl core::borrow::Borrow<$slice> for $ty {
fn borrow(&self) -> &$slice {
$slice::from_raw_slice(&self.0[..])
}
}
#[cfg(feature = "owned")]
impl alloc::borrow::ToOwned for $slice {
type Owned = $ty;
fn to_owned(&self) -> Self::Owned {
$ty(self.0.to_owned())
}
}
#[cfg(feature = "owned")]
impl core::ops::Deref for $ty {
type Target = $slice;
fn deref(&self) -> &Self::Target {
$slice::from_raw_slice(&self.0[..])
}
}
};
}
macro_rules! define_typed_vec_and_slice {
($name: ident, $slice: ident) => {
#[derive(Debug, Clone, PartialEq, Eq, Hash)]
#[cfg(feature = "owned")]
pub struct $name(Vec<u8>);
#[derive(Debug, PartialEq, Eq, Hash)]
pub struct $slice([u8]);
};
}
macro_rules! method_reslice_cast {
($name: ident, $slice: ident) => {
impl $name {
pub(crate) fn from_inner_slice<'a>(slice: &'a $slice) -> &'a $name {
unsafe { &*(slice as *const $slice as *const $name) }
}
}
};
}