Tidy Stream extension trait impl

This commit is contained in:
Tangent 128 2018-04-07 01:09:17 -04:00
parent 9ca384f9da
commit b7ee425905
4 changed files with 12 additions and 19 deletions

View file

@ -1,3 +1,2 @@
* support memory limit as toplevel limit on buffer size when Ok(None) (so only needed in futures/Read version) * support memory limit as toplevel limit on buffer size when Ok(None) (so only needed in futures/Read version)
* rustfmt modules * rustfmt modules
* bytestream source for ebml parsing

View file

@ -242,12 +242,8 @@ impl<S: EbmlEventSource> Stream for WebmChunker<S>
} }
} }
pub trait WebmStream<T: EbmlEventSource> { pub trait WebmStream where Self: Sized + EbmlEventSource {
fn chunk_webm(self) -> WebmChunker<T>; fn chunk_webm(self) -> WebmChunker<Self> {
}
impl<'a, T: EbmlEventSource> WebmStream<T> for T {
fn chunk_webm(self) -> WebmChunker<T> {
WebmChunker { WebmChunker {
source: self, source: self,
state: ChunkerState::BuildingHeader(Cursor::new(Vec::new())) state: ChunkerState::BuildingHeader(Cursor::new(Vec::new()))
@ -255,6 +251,8 @@ impl<'a, T: EbmlEventSource> WebmStream<T> for T {
} }
} }
impl<T: EbmlEventSource> WebmStream for T {}
#[cfg(test)] #[cfg(test)]
mod tests { mod tests {

View file

@ -42,12 +42,8 @@ impl<S: Stream<Item = Chunk>> Stream for ChunkTimecodeFixer<S>
} }
} }
pub trait ChunkStream<T> { pub trait ChunkStream where Self : Sized + Stream<Item = Chunk> {
fn fix_timecodes(self) -> ChunkTimecodeFixer<T>; fn fix_timecodes(self) -> ChunkTimecodeFixer<Self> {
}
impl<T: Stream<Item = Chunk>> ChunkStream<T> for T {
fn fix_timecodes(self) -> ChunkTimecodeFixer<T> {
ChunkTimecodeFixer { ChunkTimecodeFixer {
stream: self, stream: self,
current_offset: 0, current_offset: 0,
@ -57,3 +53,5 @@ impl<T: Stream<Item = Chunk>> ChunkStream<T> for T {
} }
} }
} }
impl<T: Stream<Item = Chunk>> ChunkStream for T {}

View file

@ -18,12 +18,8 @@ pub struct EbmlStreamingParser<S> {
last_read: usize last_read: usize
} }
pub trait StreamEbml<I: AsRef<[u8]>, S: Stream<Item = I>> { pub trait StreamEbml where Self: Sized + Stream, Self::Item: AsRef<[u8]> {
fn parse_ebml(self) -> EbmlStreamingParser<S>; fn parse_ebml(self) -> EbmlStreamingParser<Self> {
}
impl<I: AsRef<[u8]>, S: Stream<Item = I>> StreamEbml<I, S> for S {
fn parse_ebml(self) -> EbmlStreamingParser<S> {
EbmlStreamingParser { EbmlStreamingParser {
stream: self, stream: self,
buffer: BytesMut::new(), buffer: BytesMut::new(),
@ -32,6 +28,8 @@ impl<I: AsRef<[u8]>, S: Stream<Item = I>> StreamEbml<I, S> for S {
} }
} }
impl<I: AsRef<[u8]>, S: Stream<Item = I>> StreamEbml for S {}
impl<I: AsRef<[u8]>, S: Stream<Item = I>> EbmlStreamingParser<S> { impl<I: AsRef<[u8]>, S: Stream<Item = I>> EbmlStreamingParser<S> {
pub fn poll_event<'a, T: FromEbml<'a>>(&'a mut self) -> Result<Async<Option<T>>, ParsingError<S::Error>> { pub fn poll_event<'a, T: FromEbml<'a>>(&'a mut self) -> Result<Async<Option<T>>, ParsingError<S::Error>> {
// release buffer from previous event // release buffer from previous event