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
#![warn(missing_docs)]
#![warn(missing_copy_implementations, missing_debug_implementations)]
#![warn(unused_qualifications, unused_results)]
#![warn(future_incompatible)]
#![warn(unused)]
#![forbid(broken_intra_doc_links)]
use bytes::Bytes;
use dialectic_tokio_serde::*;
use serde::{Deserialize, Serialize};
use tokio::io::{AsyncRead, AsyncWrite};
use tokio_util::codec::length_delimited::LengthDelimitedCodec;
#[derive(Debug, Clone, Copy, Default)]
pub struct Bincode<O: bincode::Options = bincode::DefaultOptions>(O);
impl<O: bincode::Options> From<O> for Bincode<O> {
fn from(o: O) -> Self {
Bincode(o)
}
}
impl<O: bincode::Options + Clone> Serializer for Bincode<O> {
type Error = bincode::Error;
type Output = Bytes;
fn serialize<T: Serialize>(&mut self, item: &T) -> Result<Self::Output, Self::Error> {
self.0.clone().serialize(item).map(Into::into)
}
}
impl<O: bincode::Options + Clone, Input> Deserializer<Input> for Bincode<O>
where
Input: AsRef<[u8]>,
{
type Error = bincode::Error;
fn deserialize<T: for<'a> Deserialize<'a>>(&mut self, src: &Input) -> Result<T, Self::Error> {
self.0.clone().deserialize(src.as_ref())
}
}
pub fn length_delimited<W: AsyncWrite, R: AsyncRead>(
writer: W,
reader: R,
length_field_bytes: usize,
max_length: usize,
) -> (
Sender<Bincode, LengthDelimitedCodec, W>,
Receiver<Bincode, LengthDelimitedCodec, R>,
) {
let make_codec = || {
LengthDelimitedCodec::builder()
.max_frame_length(max_length)
.length_field_length(length_field_bytes)
.new_codec()
};
(
Sender::new(Bincode::default(), make_codec(), writer),
Receiver::new(Bincode::default(), make_codec(), reader),
)
}