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 read_adapter;
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::read_adapter::ReadAdapter;
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, Acceptor, WebSocketTransport, WebSocketAcceptorBuilder};
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);
}

// TODO: maybe add a default method for taking the events object
pub trait EventEmitter<T> {
    fn events(&mut self) -> Option<mpsc::UnboundedReceiver<T>>;
}