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
use std::io;
use lz4_flex::frame::{FrameDecoder, FrameEncoder};
use serde::Serialize;
use crate::Error;
impl From<bincode::Error> for Error {
fn from(b_err: bincode::Error) -> Self {
Self::IOError(std::io::Error::new(std::io::ErrorKind::Other, b_err))
}
}
impl From<lz4_flex::frame::Error> for Error {
fn from(f_err: lz4_flex::frame::Error) -> Self {
Self::IOError(std::io::Error::new(std::io::ErrorKind::Other, f_err))
}
}
pub fn serialize_into<W, T: ?Sized>(writer: W, value: &T, compress: bool) -> Result<(), Error>
where
W: io::Write,
T: Serialize,
{
if compress {
let mut encoder = FrameEncoder::new(writer);
bincode::serialize_into(&mut encoder, value)?;
encoder.finish()?;
} else {
bincode::serialize_into(writer, value)?;
};
Ok(())
}
pub fn deserialize_from<R, T>(reader: R) -> Result<T, Error>
where
R: io::Read + io::Seek,
T: serde::de::DeserializeOwned,
{
let mut decoder = FrameDecoder::new(reader);
let deserialized = match bincode::deserialize_from(&mut decoder) {
Err(_) => {
let original_reader = decoder.get_mut();
original_reader.seek(io::SeekFrom::Start(0))?;
bincode::deserialize_from(original_reader)?
}
Ok(des) => des,
};
Ok(deserialized)
}
pub fn deserialize_from_byte_slice<T>(byte_slice: &[u8]) -> Result<T, Error>
where
T: serde::de::DeserializeOwned,
{
let mut decoder = FrameDecoder::new(byte_slice);
let deserialized = match bincode::deserialize_from(&mut decoder) {
Err(_) => bincode::deserialize_from(byte_slice)?,
Ok(des) => des,
};
Ok(deserialized)
}
#[cfg(test)]
mod tests {
use std::io::Cursor;
use crate::io::serde_util::{deserialize_from, serialize_into};
fn roundtrip(compress: bool) {
let data = vec![1_i32, 2, 3, 4];
let mut data_bytes: Vec<u8> = vec![];
serialize_into(Cursor::new(&mut data_bytes), &data, compress).unwrap();
assert!(!data_bytes.is_empty());
let data2: Vec<i32> = deserialize_from(Cursor::new(&data_bytes)).unwrap();
assert_eq!(data, data2);
}
#[test]
fn test_roundtrip_no_compression() {
roundtrip(false);
}
#[test]
fn test_roundtrip_compression() {
roundtrip(true);
}
}