From 84c7ec734be6aee40e8a27a763780746c20478cd Mon Sep 17 00:00:00 2001 From: Tangent 128 Date: Tue, 5 Sep 2017 00:24:38 -0400 Subject: [PATCH] Don't require encode_ functions to consume their argument element. --- src/bin/resynth.rs | 4 ++-- src/webm.rs | 22 +++++++++++----------- 2 files changed, 13 insertions(+), 13 deletions(-) diff --git a/src/bin/resynth.rs b/src/bin/resynth.rs index 8110019..0419eb1 100644 --- a/src/bin/resynth.rs +++ b/src/bin/resynth.rs @@ -34,11 +34,11 @@ pub fn main() { let mut output = Vec::new(); let mut cursor = Cursor::new(output); - for element in head { + for element in &head { encode_webm_element(element, &mut cursor).unwrap(); } - for element in body { + for element in &body { encode_webm_element(element, &mut cursor).unwrap(); } diff --git a/src/webm.rs b/src/webm.rs index ccc313b..21ebb61 100644 --- a/src/webm.rs +++ b/src/webm.rs @@ -83,8 +83,8 @@ fn decode_simple_block(bytes: &[u8]) -> Result { } } -pub fn encode_simple_block(block: SimpleBlock, output: &mut T) -> IoResult<()> { - let SimpleBlock { +pub fn encode_simple_block(block: &SimpleBlock, output: &mut T) -> IoResult<()> { + let &SimpleBlock { track, timecode, flags, @@ -108,18 +108,18 @@ pub fn encode_simple_block(block: SimpleBlock, output: &mut T) -> IoRe output.write_all(data) } -pub fn encode_webm_element(element: WebmElement, output: &mut T) -> IoResult<()> { +pub fn encode_webm_element(element: &WebmElement, output: &mut T) -> IoResult<()> { match element { - WebmElement::EbmlHead => encode_element(EBML_HEAD_ID, output, |output| { + &WebmElement::EbmlHead => encode_element(EBML_HEAD_ID, output, |output| { encode_bytes(DOC_TYPE_ID, "webm".as_bytes(), output) }), - WebmElement::Segment => encode_tag_header(SEGMENT_ID, Varint::Unknown, output), - WebmElement::SeekHead => Ok(()), - WebmElement::Cues => Ok(()), - WebmElement::Tracks(data) => encode_bytes(TRACKS_ID, data, output), - WebmElement::Cluster => encode_tag_header(CLUSTER_ID, Varint::Unknown, output), - WebmElement::Timecode(time) => encode_integer(TIMECODE_ID, time, output), - WebmElement::SimpleBlock(block) => encode_simple_block(block, output), + &WebmElement::Segment => encode_tag_header(SEGMENT_ID, Varint::Unknown, output), + &WebmElement::SeekHead => Ok(()), + &WebmElement::Cues => Ok(()), + &WebmElement::Tracks(data) => encode_bytes(TRACKS_ID, data, output), + &WebmElement::Cluster => encode_tag_header(CLUSTER_ID, Varint::Unknown, output), + &WebmElement::Timecode(time) => encode_integer(TIMECODE_ID, time, output), + &WebmElement::SimpleBlock(ref block) => encode_simple_block(block, output), _ => Err(IoError::new(ErrorKind::InvalidInput, WriteError::OutOfRange)) } }