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
123
use assembly_core::buffer::{CastError, MinimallyAligned, Repr};
use self::buffer::Buffer;
use super::file::ArrayHeader;
pub mod buffer;
pub mod handle;
pub mod slice;
#[derive(Copy, Clone, Debug)]
pub struct Handle<'a, T> {
pub(super) buffer: Buffer<'a>,
pub(super) raw: T,
}
impl<'a, T> Handle<'a, T> {
pub fn raw(&self) -> &T {
&self.raw
}
pub fn raw_mut(&mut self) -> &mut T {
&mut self.raw
}
pub fn buf(self) -> Buffer<'a> {
self.buffer
}
pub fn into_raw(self) -> T {
self.raw
}
pub(crate) fn wrap<R>(&self, raw: R) -> Handle<'a, R> {
Handle {
buffer: self.buffer,
raw,
}
}
pub(crate) fn try_map_cast<R: MinimallyAligned>(
&self,
offset: u32,
) -> Result<RefHandle<'a, R>, CastError> {
let raw: &'a R = self.buffer.try_cast(offset)?;
Ok(self.wrap(raw))
}
pub(crate) fn try_map_cast_slice<R: MinimallyAligned>(
&self,
offset: u32,
count: u32,
) -> Result<RefHandle<'a, [R]>, CastError> {
let raw: &'a [R] = self.buffer.try_cast_slice(offset, count)?;
Ok(self.wrap(raw))
}
pub(crate) fn try_map_cast_array<R: MinimallyAligned>(
&self,
array: ArrayHeader,
) -> Result<RefHandle<'a, [R]>, CastError> {
let raw: &'a [R] = self.buffer.try_cast_slice(array.base_offset, array.count)?;
Ok(self.wrap(raw))
}
pub fn map<X>(self, mapper: impl Fn(Buffer<'a>, T) -> X) -> Handle<'a, X> {
let raw = mapper(self.buffer, self.raw);
Handle {
buffer: self.buffer,
raw,
}
}
pub fn map_val<X>(self, mapper: impl Fn(T) -> X) -> Handle<'a, X> {
let raw = mapper(self.raw);
Handle {
buffer: self.buffer,
raw,
}
}
pub fn try_map<X, E>(
self,
mapper: impl Fn(Buffer<'a>, T) -> Result<X, E>,
) -> Result<Handle<'a, X>, E> {
let raw = mapper(self.buffer, self.raw)?;
Ok(Handle {
buffer: self.buffer,
raw,
})
}
}
impl<'a, T> RefHandle<'a, [T]> {
pub fn get(self, index: usize) -> Option<RefHandle<'a, T>> {
self.raw.get(index).map(|raw| self.wrap(raw))
}
}
pub type RefHandle<'a, T> = Handle<'a, &'a T>;
impl<'a, T: Repr> RefHandle<'a, T> {
pub fn map_extract(self) -> Handle<'a, T::Value> {
self.wrap(self.raw.extract())
}
}