Better-adapt extend_timespan to its real use, observe_simpleblock_timecode

This commit is contained in:
Tangent 128 2017-10-04 01:48:33 -04:00
parent 0aa2f1cbdd
commit 9c9db1c505
2 changed files with 5 additions and 4 deletions

View file

@ -92,7 +92,7 @@ fn create_loop() -> WebmServer {
// TODO: this is incorrect, condition needs to also affirm we're the first video block of the cluster // TODO: this is incorrect, condition needs to also affirm we're the first video block of the cluster
chunk.mark_keyframe(true); chunk.mark_keyframe(true);
} }
chunk.extend_timespan(cluster_timecode + (block.timecode as u64)); chunk.observe_simpleblock_timecode(block.timecode);
} }
encode_webm_element(&SimpleBlock(*block), &mut buffer).unwrap(); encode_webm_element(&SimpleBlock(*block), &mut buffer).unwrap();
}, },

View file

@ -47,10 +47,11 @@ impl<B: AsRef<[u8]>> Chunk<B> {
*bytes_used = cursor.position() as u8; *bytes_used = cursor.position() as u8;
} }
} }
pub fn extend_timespan(&mut self, timecode: u64) { pub fn observe_simpleblock_timecode(&mut self, timecode: i16) {
if let &mut Chunk::ClusterHead {start, ref mut end, ..} = self { if let &mut Chunk::ClusterHead {start, ref mut end, ..} = self {
if timecode > start { let absolute_timecode = start + (timecode as u64);
*end = timecode; if absolute_timecode > start {
*end = absolute_timecode;
} }
} }
} }