add chunk mutators/utilities
This commit is contained in:
parent
031d32352a
commit
a7804891ae
1 changed files with 24 additions and 0 deletions
24
src/chunk.rs
24
src/chunk.rs
|
@ -21,6 +21,18 @@ pub enum Chunk<B: AsRef<[u8]> = Vec<u8>> {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<B: AsRef<[u8]>> Chunk<B> {
|
impl<B: AsRef<[u8]>> Chunk<B> {
|
||||||
|
pub fn new_cluster_head(timecode: u64) -> Chunk {
|
||||||
|
let mut chunk = Chunk::ClusterHead {
|
||||||
|
keyframe: false,
|
||||||
|
start: 0,
|
||||||
|
end: 0,
|
||||||
|
bytes: [0;16],
|
||||||
|
bytes_used: 0
|
||||||
|
};
|
||||||
|
chunk.update_timecode(timecode);
|
||||||
|
chunk
|
||||||
|
}
|
||||||
|
|
||||||
pub fn update_timecode(&mut self, timecode: u64) {
|
pub fn update_timecode(&mut self, timecode: u64) {
|
||||||
if let &mut Chunk::ClusterHead {ref mut start, ref mut end, ref mut bytes, ref mut bytes_used, ..} = self {
|
if let &mut Chunk::ClusterHead {ref mut start, ref mut end, ref mut bytes, ref mut bytes_used, ..} = self {
|
||||||
let delta = *end - *start;
|
let delta = *end - *start;
|
||||||
|
@ -33,6 +45,18 @@ 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) {
|
||||||
|
if let &mut Chunk::ClusterHead {start, ref mut end, ..} = self {
|
||||||
|
if timecode > start {
|
||||||
|
*end = timecode;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pub fn mark_keyframe(&mut self, new_keyframe: bool) {
|
||||||
|
if let &mut Chunk::ClusterHead {ref mut keyframe, ..} = self {
|
||||||
|
*keyframe = new_keyframe;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<B: AsRef<[u8]>> AsRef<[u8]> for Chunk<B> {
|
impl<B: AsRef<[u8]>> AsRef<[u8]> for Chunk<B> {
|
||||||
|
|
Loading…
Reference in a new issue