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
124
125
126
use std::io::{BufReader, Read};
use std::net::{TcpListener, TcpStream, ToSocketAddrs};
use std::marker::PhantomData;
use bincode::Config;
use byteorder::ReadBytesExt;
use serde::de::DeserializeOwned;
use crate::{ChannelRecv, Endian, BigEndian, RecvError};
pub const DEFAULT_MAX_SIZE: usize = 64 * 0x100_000;
pub struct Receiver<T: DeserializeOwned, E: Endian, R: Read = BufReader<TcpStream>> {
reader: R,
config: Config,
max_size: usize,
_marker: PhantomData<(T, E)>,
}
pub struct ReceiverBuilder;
pub struct TypedReceiverBuilder<T, R, E> {
_marker: PhantomData<(T, R, E)>,
max_size: usize,
}
impl ReceiverBuilder {
pub fn new() -> TypedReceiverBuilder<(), BufReader<TcpStream>, BigEndian> {
Self::buffered()
}
pub fn buffered() -> TypedReceiverBuilder<(), BufReader<TcpStream>, BigEndian> {
TypedReceiverBuilder {
_marker: PhantomData,
max_size: DEFAULT_MAX_SIZE,
}
}
pub fn realtime() -> TypedReceiverBuilder<(), TcpStream, BigEndian> {
TypedReceiverBuilder {
_marker: PhantomData,
max_size: DEFAULT_MAX_SIZE,
}
}
}
impl<T, R, E> TypedReceiverBuilder<T, R, E> {
pub fn with_type<U: DeserializeOwned>(self) -> TypedReceiverBuilder<U, R, E> {
TypedReceiverBuilder {
_marker: PhantomData,
max_size: self.max_size,
}
}
pub fn with_reader<S: Read>(self) -> TypedReceiverBuilder<T, S, E> {
TypedReceiverBuilder {
_marker: PhantomData,
max_size: self.max_size,
}
}
pub fn with_endianness<F: Endian>(self) -> TypedReceiverBuilder<T, R, F> {
TypedReceiverBuilder {
_marker: PhantomData,
max_size: self.max_size,
}
}
}
impl<T: DeserializeOwned, R: Read, E: Endian> TypedReceiverBuilder<T, R, E> {
pub fn build(self, reader: R) -> Receiver<T, E, R> {
Receiver {
_marker: PhantomData,
reader,
config: E::config(),
max_size: self.max_size,
}
}
}
impl<T: DeserializeOwned, E: Endian> TypedReceiverBuilder<T, BufReader<TcpStream>, E> {
pub fn listen_once<A: ToSocketAddrs>(self, address: A) -> std::io::Result<Receiver<T, E, BufReader<TcpStream>>> {
let listener = TcpListener::bind(address)?;
let (stream, _) = listener.accept()?;
Ok(Receiver {
config: E::config(),
_marker: PhantomData,
reader: BufReader::new(stream),
max_size: self.max_size,
})
}
}
impl<T: DeserializeOwned, E: Endian> TypedReceiverBuilder<T, TcpStream, E> {
pub fn listen_once<A: ToSocketAddrs>(self, address: A) -> std::io::Result<Receiver<T, E, TcpStream>> {
let listener = TcpListener::bind(address)?;
let (stream, _) = listener.accept()?;
stream.set_nodelay(true)?;
Ok(Receiver {
config: E::config(),
_marker: PhantomData,
reader: stream,
max_size: self.max_size,
})
}
}
impl<T: DeserializeOwned, E: Endian, R: Read> ChannelRecv<T> for Receiver<T, E, R> {
type Error = RecvError;
fn recv(&mut self) -> Result<T, RecvError> {
let length = self.reader.read_u64::<E>()? as usize;
if length > self.max_size {
return Err(RecvError::TooLarge(length))
}
let mut buffer = vec! [0; length];
self.reader.read_exact(&mut buffer)?;
Ok(self.config.deserialize(&buffer)?)
}
}