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
mod decode;
mod encode;
pub mod filler;
pub mod zigzag;
pub mod en {
pub use super::encode::*;
}
pub mod de {
pub use super::decode::*;
}
pub trait Flat<'b>: en::Encode + de::Decode<'b> {
fn flat(&self) -> Result<Vec<u8>, en::Error> {
encode(self)
}
fn unflat(bytes: &'b [u8]) -> Result<Self, de::Error> {
decode(bytes)
}
}
pub fn encode<T>(value: &T) -> Result<Vec<u8>, en::Error>
where
T: en::Encode,
{
let mut e = en::Encoder::new();
value.encode(&mut e)?;
e.encode(filler::Filler::FillerEnd)?;
Ok(e.buffer)
}
pub fn decode<'b, T>(bytes: &'b [u8]) -> Result<T, de::Error>
where
T: de::Decode<'b>,
{
let mut d = de::Decoder::new(bytes);
let value = d.decode()?;
d.decode::<filler::Filler>()?;
Ok(value)
}
#[cfg(test)]
mod test {
#[test]
fn encode_bool() {
let bytes = super::encode(&true).unwrap();
assert_eq!(bytes, vec![0b10000001]);
let bytes = super::encode(&false).unwrap();
assert_eq!(bytes, vec![0b00000001]);
}
#[test]
fn encode_u8() {
let bytes = super::encode(&3_u8).unwrap();
assert_eq!(bytes, vec![0b00000011, 0b00000001]);
}
}