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
extern crate libc;
extern crate users;
extern crate futures;
extern crate bytes;
#[macro_use]
extern crate tokio;
extern crate tokio_io;
extern crate tokio_codec;
extern crate tokio_uds;
extern crate tokio_tcp;
extern crate tokio_udp;
extern crate tokio_timer;
extern crate serde;
extern crate serde_json;
#[cfg(test)]
#[macro_use]
extern crate serde_derive;
extern crate tokio_serde_json_mirror as tokio_serde_json;
#[macro_use]
extern crate log;
extern crate uuid;
trait GenericServer {
type Address;
type Request;
type Response;
fn send(&mut self, _: Self::Address);
}
pub mod server;
pub use crate::server::Server;
pub mod connection;
pub use crate::connection::Connection;
pub mod codecs;
pub mod tcp;
pub use crate::tcp::{TcpServer, TcpInfo, TcpConnection};
pub mod udp;
pub use crate::udp::{UdpConnection, UdpInfo};
pub mod unix;
pub use crate::unix::{UnixServer, UnixInfo, UnixConnection};
pub mod error;
pub use crate::error::Error as DaemonError;
pub type JsonCodec<Req, Resp> = codecs::json::JsonCodec<Req, Resp, codecs::json::JsonError>;
use futures::{future, Future, sync::oneshot};
pub trait AsyncWait<I, E> {
fn async_wait(self) -> Result<I, E>;
}
impl <F, I, E> AsyncWait<I, E> for F
where
F: Future<Item=I, Error=E> + Send + 'static,
I: Send + 'static,
E: Send + 'static,
{
fn async_wait(self) -> Result<I, E> {
let (tx, rx) = oneshot::channel::<Result<I, E>>();
tokio::spawn(self.then(|res| tx.send(res) ).map(|_v| () ).map_err(|_e| () ));
rx.wait().unwrap()
}
}