Split apart iterator and slice modules

This commit is contained in:
Tangent 128 2018-04-04 00:43:25 -04:00
parent 9686eb2713
commit 3a92da1883
4 changed files with 41 additions and 29 deletions

View file

@ -1,12 +1,15 @@
use futures::Async; use std::marker::PhantomData;
use ebml::EbmlError;
use ebml::EbmlEventSource;
use ebml::FromEbml; use ebml::FromEbml;
use webm::WebmElement; use webm::WebmElement;
pub struct EbmlSlice<'a>(pub &'a [u8]); pub struct EbmlIterator<'a, T: FromEbml<'a>>(&'a [u8], PhantomData<fn() -> T>);
impl<'a> Iterator for EbmlSlice<'a> { pub fn ebml_iter<'a, T: FromEbml<'a>>(source: &'a [u8])-> EbmlIterator<'a, T> {
EbmlIterator(source, PhantomData)
}
impl<'a, T: FromEbml<'a>> Iterator for EbmlIterator<'a, T> {
type Item = WebmElement<'a>; type Item = WebmElement<'a>;
fn next(&mut self) -> Option<WebmElement<'a>> { fn next(&mut self) -> Option<WebmElement<'a>> {
@ -21,24 +24,3 @@ impl<'a> Iterator for EbmlSlice<'a> {
}) })
} }
} }
impl<'b> EbmlEventSource for EbmlSlice<'b> {
type Error = EbmlError;
fn poll_event<'a, T: FromEbml<'a>>(&'a mut self) -> Result<Async<Option<T>>, EbmlError> {
T::check_space(self.0).and_then(|size_option| {
match size_option {
None => Ok(None),
Some(element_size) => {
let (element_data, rest) = self.0.split_at(element_size);
self.0 = rest;
match T::decode_element(element_data) {
Err(err) => Err(err),
Ok(None) => panic!("Buffer was supposed to have enough data to parse element, somehow did not."),
Ok(Some((element, _))) => Ok(Some(element))
}
}
}
}).map(Async::Ready)
}
}

View file

@ -5,6 +5,8 @@ extern crate futures;
pub mod chunk; pub mod chunk;
pub mod ebml; pub mod ebml;
mod iterator; mod iterator;
pub mod slice;
pub mod webm_stream; pub mod webm_stream;
pub mod timecode_fixer; pub mod timecode_fixer;
pub mod webm; pub mod webm;

27
src/slice.rs Normal file
View file

@ -0,0 +1,27 @@
use futures::Async;
use ebml::EbmlError;
use ebml::EbmlEventSource;
use ebml::FromEbml;
pub struct EbmlSlice<'a>(pub &'a [u8]);
impl<'b> EbmlEventSource for EbmlSlice<'b> {
type Error = EbmlError;
fn poll_event<'a, T: FromEbml<'a>>(&'a mut self) -> Result<Async<Option<T>>, EbmlError> {
T::check_space(self.0).and_then(|size_option| {
match size_option {
None => Ok(None),
Some(element_size) => {
let (element_data, rest) = self.0.split_at(element_size);
self.0 = rest;
match T::decode_element(element_data) {
Err(err) => Err(err),
Ok(None) => panic!("Buffer was supposed to have enough data to parse element, somehow did not."),
Ok(Some((element, _))) => Ok(Some(element))
}
}
}
}).map(Async::Ready)
}
}

View file

@ -1,7 +1,8 @@
use std::io::{Cursor, Error as IoError, ErrorKind, Result as IoResult, Write, Seek}; use std::io::{Cursor, Error as IoError, ErrorKind, Result as IoResult, Write, Seek};
use bytes::{BigEndian, BufMut, ByteOrder}; use bytes::{BigEndian, BufMut, ByteOrder};
use ebml::*; use ebml::*;
use iterator::EbmlSlice; use iterator::ebml_iter;
use iterator::EbmlIterator;
const SEGMENT_ID: u64 = 0x08538067; const SEGMENT_ID: u64 = 0x08538067;
const SEEK_HEAD_ID: u64 = 0x014D9B74; const SEEK_HEAD_ID: u64 = 0x014D9B74;
@ -12,8 +13,8 @@ const CLUSTER_ID: u64 = 0x0F43B675;
const TIMECODE_ID: u64 = 0x67; const TIMECODE_ID: u64 = 0x67;
const SIMPLE_BLOCK_ID: u64 = 0x23; const SIMPLE_BLOCK_ID: u64 = 0x23;
pub fn parse_webm<'a, T: AsRef<[u8]> + ?Sized>(source: &'a T) -> EbmlSlice<'a> { pub fn parse_webm<'a, T: AsRef<[u8]> + ?Sized>(source: &'a T) -> EbmlIterator<'a, WebmElement> {
EbmlSlice(source.as_ref()) ebml_iter(source.as_ref())
} }
#[derive(Debug, PartialEq, Copy, Clone)] #[derive(Debug, PartialEq, Copy, Clone)]