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()
}
}