Remove EbmlEventSource trait in favor of concrete EbmlStreamingParser

This commit is contained in:
Tangent 128 2019-10-21 01:20:14 -04:00
parent fa85939c0b
commit eda2e4f7be
3 changed files with 13 additions and 26 deletions

View file

@ -1,10 +1,10 @@
use bytes::Bytes; use bytes::{Buf, Bytes};
use futures::{Async, Stream}; use futures::{Async, Stream};
use std::{ use std::{
io::Cursor, io::Cursor,
mem mem
}; };
use crate::ebml::EbmlEventSource; use crate::stream_parser::EbmlStreamingParser;
use crate::error::WebmetroError; use crate::error::WebmetroError;
use crate::webm::*; use crate::webm::*;
@ -103,7 +103,7 @@ enum ChunkerState {
} }
pub struct WebmChunker<S> { pub struct WebmChunker<S> {
source: S, source: EbmlStreamingParser<S>,
buffer_size_limit: Option<usize>, buffer_size_limit: Option<usize>,
state: ChunkerState state: ChunkerState
} }
@ -128,8 +128,7 @@ fn encode(element: WebmElement, buffer: &mut Cursor<Vec<u8>>, limit: Option<usiz
encode_webm_element(element, buffer).map_err(|err| err.into()) encode_webm_element(element, buffer).map_err(|err| err.into())
} }
impl<S: EbmlEventSource> Stream for WebmChunker<S> impl<I: Buf, S: Stream<Item = I, Error = WebmetroError>> Stream for WebmChunker<S>
where S::Error: Into<WebmetroError>
{ {
type Item = Chunk; type Item = Chunk;
type Error = WebmetroError; type Error = WebmetroError;
@ -266,8 +265,14 @@ where S::Error: Into<WebmetroError>
} }
} }
pub trait WebmStream where Self: Sized + EbmlEventSource { pub trait WebmStream {
fn chunk_webm(self) -> WebmChunker<Self> { type Stream;
fn chunk_webm(self) -> WebmChunker<Self::Stream>;
}
impl<S: Stream> WebmStream for EbmlStreamingParser<S> {
type Stream = S;
fn chunk_webm(self) -> WebmChunker<S> {
WebmChunker { WebmChunker {
source: self, source: self,
buffer_size_limit: None, buffer_size_limit: None,
@ -276,8 +281,6 @@ pub trait WebmStream where Self: Sized + EbmlEventSource {
} }
} }
impl<T: EbmlEventSource> WebmStream for T {}
#[cfg(test)] #[cfg(test)]
mod tests { mod tests {

View file

@ -1,7 +1,6 @@
use bytes::{BigEndian, ByteOrder, BufMut}; use bytes::{BigEndian, ByteOrder, BufMut};
use custom_error::custom_error; use custom_error::custom_error;
use std::io::{Cursor, Error as IoError, ErrorKind, Result as IoResult, Write, Seek, SeekFrom}; use std::io::{Cursor, Error as IoError, ErrorKind, Result as IoResult, Write, Seek, SeekFrom};
use futures::Async;
pub const EBML_HEAD_ID: u64 = 0x0A45DFA3; pub const EBML_HEAD_ID: u64 = 0x0A45DFA3;
pub const DOC_TYPE_ID: u64 = 0x0282; pub const DOC_TYPE_ID: u64 = 0x0282;
@ -261,11 +260,6 @@ pub trait FromEbml<'a>: Sized {
} }
} }
pub trait EbmlEventSource {
type Error;
fn poll_event<'a, T: FromEbml<'a>>(&'a mut self) -> Result<Async<Option<T>>, Self::Error>;
}
#[cfg(test)] #[cfg(test)]
mod tests { mod tests {
use bytes::{BytesMut}; use bytes::{BytesMut};

View file

@ -1,7 +1,7 @@
use bytes::{Buf, BufMut, Bytes, BytesMut}; use bytes::{Buf, BufMut, Bytes, BytesMut};
use futures::{stream::Stream, Async}; use futures::{stream::Stream, Async};
use crate::ebml::{EbmlEventSource, FromEbml}; use crate::ebml::FromEbml;
use crate::error::WebmetroError; use crate::error::WebmetroError;
pub struct EbmlStreamingParser<S> { pub struct EbmlStreamingParser<S> {
@ -76,16 +76,6 @@ impl<I: Buf, S: Stream<Item = I, Error = WebmetroError>> EbmlStreamingParser<S>
} }
} }
impl<I: Buf, S: Stream<Item = I, Error = WebmetroError>> EbmlEventSource
for EbmlStreamingParser<S>
{
type Error = WebmetroError;
fn poll_event<'a, T: FromEbml<'a>>(&'a mut self) -> Result<Async<Option<T>>, WebmetroError> {
return EbmlStreamingParser::poll_event(self);
}
}
#[cfg(test)] #[cfg(test)]
mod tests { mod tests {
use bytes::IntoBuf; use bytes::IntoBuf;