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
use crate::*;
#[derive(Clone, Eq, PartialEq, Debug)]
pub struct ObjectLink {
pub obj_id: ObjectId,
pub obj_owner: Option<ObjectId>,
}
impl RawEncode for ObjectLink {
fn raw_measure(&self, purpose: &Option<RawEncodePurpose>) -> Result<usize, BuckyError> {
Ok(ObjectId::raw_bytes().unwrap()
+ self.obj_owner.raw_measure(purpose).map_err(|e| {
log::error!("ObjectId::raw_measure error:{}", e);
e
})?)
}
fn raw_encode<'a>(
&self,
buf: &'a mut [u8],
purpose: &Option<RawEncodePurpose>,
) -> BuckyResult<&'a mut [u8]> {
let bytes = self.raw_measure(purpose).unwrap();
if buf.len() < bytes {
let msg = format!(
"not enough buffer for encode ObjectLink, except={}, got={}",
bytes,
buf.len()
);
error!("{}", msg);
return Err(BuckyError::new(BuckyErrorCode::OutOfLimit, msg));
}
let buf = self.obj_id.raw_encode(buf, purpose).map_err(|e| {
log::error!("ObjectId::raw_encode/obj_id error:{}", e);
e
})?;
let buf = self.obj_owner.raw_encode(buf, purpose).map_err(|e| {
log::error!("ObjectId::raw_encode/obj_owner error:{}", e);
e
})?;
Ok(buf)
}
}
impl<'de> RawDecode<'de> for ObjectLink {
fn raw_decode(buf: &'de [u8]) -> BuckyResult<(Self, &'de [u8])> {
let (obj_id, buf) = ObjectId::raw_decode(buf).map_err(|e| {
log::error!("ObjectId::raw_decode/obj_id error:{}", e);
e
})?;
let (obj_owner, buf) = Option::<ObjectId>::raw_decode(buf).map_err(|e| {
log::error!("ObjectId::raw_decode/obj_owner error:{}", e);
e
})?;
Ok((Self { obj_id, obj_owner }, buf))
}
}