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
use futures::sync::mpsc;
mod write_adapter;
mod sink_adapter;
mod map_conduit;
mod range_producer;
mod transport;
mod multiplexer;
mod producer;
mod consumer;
pub mod runtime {
use futures::future::lazy;
pub fn run(f: fn()) {
tokio::run(lazy(move || {
f();
Ok(())
}));
}
}
pub use self::write_adapter::WriteAdapter;
pub use self::sink_adapter::SinkAdapter;
pub use self::range_producer::{RangeProducer, RangeProducerBuilder};
pub use self::map_conduit::{MapConduit, MapConsumer, MapProducer};
pub use self::transport::{Transport};
pub use self::multiplexer::{Multiplexer, MultiplexerEvent};
pub use self::producer::{
Producer, ProducerEvent, ProducerEventRx, ProducerEventTx,
ProducerMessage, ProducerMessageRx, ProducerMessageTx,
ProducerEventEmitter,
};
pub use self::consumer::{
Consumer, ConsumerEvent, ConsumerEventRx, ConsumerEventTx,
ConsumerMessage, ConsumerMessageRx, ConsumerMessageTx,
};
pub type Message = Vec<u8>;
#[derive(PartialEq, Clone, Debug)]
pub enum CancelReason {
Disconnected,
Other(String),
}
pub trait Streamer {
fn cancel(&mut self, reason: CancelReason);
}
pub trait Conduit<A, B> : Consumer<A> + Producer<B>
where B: Send + 'static
{
type ConcreteConsumer: Consumer<A>;
type ConcreteProducer: Producer<B>;
fn split(self) -> (Self::ConcreteConsumer, Self::ConcreteProducer);
}
pub trait EventEmitter<T> {
fn events(&mut self) -> Option<mpsc::UnboundedReceiver<T>>;
}