Use Never type & add missing Transmitter::new() to channel.rs
This commit is contained in:
parent
adea1e4389
commit
075c840a46
1 changed files with 16 additions and 6 deletions
|
@ -18,6 +18,8 @@ use odds::vec::VecExt;
|
||||||
|
|
||||||
use chunk::Chunk;
|
use chunk::Chunk;
|
||||||
|
|
||||||
|
pub enum Never {}
|
||||||
|
|
||||||
/// A collection of listeners to a stream of WebM chunks.
|
/// A collection of listeners to a stream of WebM chunks.
|
||||||
/// Sending a chunk may fail due to a client being disconnected,
|
/// Sending a chunk may fail due to a client being disconnected,
|
||||||
/// or simply failing to keep up with the stream buffer. In either
|
/// or simply failing to keep up with the stream buffer. In either
|
||||||
|
@ -41,11 +43,19 @@ pub struct Transmitter {
|
||||||
channel: Arc<Mutex<Channel>>
|
channel: Arc<Mutex<Channel>>
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl Transmitter {
|
||||||
|
pub fn new(channel_arc: Arc<Mutex<Channel>>) -> Self {
|
||||||
|
Transmitter {
|
||||||
|
channel: channel_arc
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl Sink for Transmitter {
|
impl Sink for Transmitter {
|
||||||
type SinkItem = Chunk;
|
type SinkItem = Chunk;
|
||||||
type SinkError = (); // never errors, slow clients are simply dropped
|
type SinkError = Never; // never errors, slow clients are simply dropped
|
||||||
|
|
||||||
fn start_send(&mut self, chunk: Chunk) -> Result<AsyncSink<Chunk>, ()> {
|
fn start_send(&mut self, chunk: Chunk) -> Result<AsyncSink<Chunk>, Never> {
|
||||||
let mut channel = self.channel.lock().expect("Locking channel");
|
let mut channel = self.channel.lock().expect("Locking channel");
|
||||||
|
|
||||||
if let Chunk::Headers { .. } = chunk {
|
if let Chunk::Headers { .. } = chunk {
|
||||||
|
@ -56,7 +66,7 @@ impl Sink for Transmitter {
|
||||||
|
|
||||||
Ok(AsyncSink::Ready)
|
Ok(AsyncSink::Ready)
|
||||||
}
|
}
|
||||||
fn poll_complete(&mut self) -> Result<Async<()>, ()> {
|
fn poll_complete(&mut self) -> Result<Async<()>, Never> {
|
||||||
let mut channel = self.channel.lock().expect("Locking channel");
|
let mut channel = self.channel.lock().expect("Locking channel");
|
||||||
|
|
||||||
channel.listeners.retain_mut(|listener| listener.poll_complete().is_ok());
|
channel.listeners.retain_mut(|listener| listener.poll_complete().is_ok());
|
||||||
|
@ -94,9 +104,9 @@ impl Listener {
|
||||||
|
|
||||||
impl Stream for Listener {
|
impl Stream for Listener {
|
||||||
type Item = Chunk;
|
type Item = Chunk;
|
||||||
type Error = (); // no transmitter errors are exposed to the listeners
|
type Error = Never; // no transmitter errors are exposed to the listeners
|
||||||
|
|
||||||
fn poll(&mut self) -> Result<Async<Option<Chunk>>, ()> {
|
fn poll(&mut self) -> Result<Async<Option<Chunk>>, Never> {
|
||||||
self.receiver.poll()
|
Ok(self.receiver.poll().expect("Channel receiving can't error"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue