Implement rewriting timestamps for chunks
This commit is contained in:
parent
bad7b42e5b
commit
27aff20c46
2 changed files with 24 additions and 4 deletions
1
notes.md
1
notes.md
|
@ -1,5 +1,4 @@
|
||||||
* 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
|
||||||
* timestamp fix for chunks (stream modifier/extension method)
|
|
||||||
* create chunks from webm event stream
|
* create chunks from webm event stream
|
||||||
* bytestream source for ebml parsing
|
* bytestream source for ebml parsing
|
||||||
|
|
|
@ -45,7 +45,10 @@ impl TimecodeFixer {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct ChunkTimecodeFixer<S> {
|
pub struct ChunkTimecodeFixer<S> {
|
||||||
stream: S
|
stream: S,
|
||||||
|
current_offset: u64,
|
||||||
|
last_observed_timecode: u64,
|
||||||
|
assumed_duration: u64,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<S: Stream<Item = Chunk>> Stream for ChunkTimecodeFixer<S>
|
impl<S: Stream<Item = Chunk>> Stream for ChunkTimecodeFixer<S>
|
||||||
|
@ -54,7 +57,22 @@ impl<S: Stream<Item = Chunk>> Stream for ChunkTimecodeFixer<S>
|
||||||
type Error = S::Error;
|
type Error = S::Error;
|
||||||
|
|
||||||
fn poll(&mut self) -> Result<Async<Option<Self::Item>>, Self::Error> {
|
fn poll(&mut self) -> Result<Async<Option<Self::Item>>, Self::Error> {
|
||||||
self.stream.poll()
|
let mut poll_chunk = self.stream.poll();
|
||||||
|
match poll_chunk {
|
||||||
|
Ok(Async::Ready(Some(Chunk::ClusterHead {start, end, ..}))) => {
|
||||||
|
if start < self.last_observed_timecode {
|
||||||
|
let next_timecode = self.last_observed_timecode + self.assumed_duration;
|
||||||
|
self.current_offset = next_timecode - start;
|
||||||
|
}
|
||||||
|
|
||||||
|
if let Ok(Async::Ready(Some(ref mut cluster_head))) = poll_chunk {
|
||||||
|
cluster_head.update_timecode(start + self.current_offset);
|
||||||
|
}
|
||||||
|
self.last_observed_timecode = end + self.current_offset;
|
||||||
|
},
|
||||||
|
_ => {}
|
||||||
|
};
|
||||||
|
poll_chunk
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -65,7 +83,10 @@ pub trait ChunkStream<T> {
|
||||||
impl<T: Stream<Item = Chunk>> ChunkStream<T> for T {
|
impl<T: Stream<Item = Chunk>> ChunkStream<T> for T {
|
||||||
fn fix_timecodes(self) -> ChunkTimecodeFixer<T> {
|
fn fix_timecodes(self) -> ChunkTimecodeFixer<T> {
|
||||||
ChunkTimecodeFixer {
|
ChunkTimecodeFixer {
|
||||||
stream: self
|
stream: self,
|
||||||
|
current_offset: 0,
|
||||||
|
last_observed_timecode: 0,
|
||||||
|
assumed_duration: 33
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue