Cleanup results more

This commit is contained in:
Tangent 128 2017-08-07 01:11:43 -04:00
parent c969627510
commit 120fe26b6b

View file

@ -131,7 +131,7 @@ const EIGHT_FLAG: u64 = 0x01 << (8*7);
const EIGHT_MAX: u64 = EIGHT_FLAG - 2; const EIGHT_MAX: u64 = EIGHT_FLAG - 2;
/// Tries to write an EBML varint using minimal space /// Tries to write an EBML varint using minimal space
pub fn encode_varint<T: Write>(varint: Varint, output: &mut T) -> IoResult<usize> { pub fn encode_varint<T: Write>(varint: Varint, output: &mut T) -> IoResult<()> {
let (size, number) = match varint { let (size, number) = match varint {
Varint::Unknown => (1, 0xFF), Varint::Unknown => (1, 0xFF),
Varint::Value(too_big) if too_big > EIGHT_MAX => { Varint::Value(too_big) if too_big > EIGHT_MAX => {
@ -155,14 +155,14 @@ pub fn encode_varint<T: Write>(varint: Varint, output: &mut T) -> IoResult<usize
let mut buffer = Cursor::new([0; 8]); let mut buffer = Cursor::new([0; 8]);
buffer.put_uint::<BigEndian>(number, size); buffer.put_uint::<BigEndian>(number, size);
return output.write_all(&buffer.get_ref()[..size]).map(|()| size); return output.write_all(&buffer.get_ref()[..size]);
} }
const FOUR_FLAG: u64 = 0x10 << (8*3); const FOUR_FLAG: u64 = 0x10 << (8*3);
const FOUR_MAX: u64 = FOUR_FLAG - 2; const FOUR_MAX: u64 = FOUR_FLAG - 2;
// tries to write a varint with a fixed 4-byte representation // tries to write a varint with a fixed 4-byte representation
pub fn encode_varint_4<T: Write>(varint: Varint, output: &mut T) -> IoResult<usize> { pub fn encode_varint_4<T: Write>(varint: Varint, output: &mut T) -> IoResult<()> {
let number = match varint { let number = match varint {
Varint::Unknown => FOUR_FLAG | (FOUR_FLAG - 1), Varint::Unknown => FOUR_FLAG | (FOUR_FLAG - 1),
Varint::Value(too_big) if too_big > FOUR_MAX => { Varint::Value(too_big) if too_big > FOUR_MAX => {
@ -174,7 +174,7 @@ pub fn encode_varint_4<T: Write>(varint: Varint, output: &mut T) -> IoResult<usi
let mut buffer = Cursor::new([0; 4]); let mut buffer = Cursor::new([0; 4]);
buffer.put_u32::<BigEndian>(number as u32); buffer.put_u32::<BigEndian>(number as u32);
return output.write_all(&buffer.get_ref()[..]).map(|()| 4); output.write_all(&buffer.get_ref()[..])
} }
pub fn encode_element<T: Write + Seek, F: Fn(&mut T) -> IoResult<X>, X>(tag: u64, output: &mut T, content: F) -> IoResult<()> { pub fn encode_element<T: Write + Seek, F: Fn(&mut T) -> IoResult<X>, X>(tag: u64, output: &mut T, content: F) -> IoResult<()> {
@ -194,15 +194,14 @@ pub fn encode_element<T: Write + Seek, F: Fn(&mut T) -> IoResult<X>, X>(tag: u64
pub fn encode_tag_header<T: Write>(tag: u64, size: Varint, output: &mut T) -> IoResult<()> { pub fn encode_tag_header<T: Write>(tag: u64, size: Varint, output: &mut T) -> IoResult<()> {
encode_varint(Varint::Value(tag), output)?; encode_varint(Varint::Value(tag), output)?;
encode_varint(size, output)?; encode_varint(size, output)
Ok(())
} }
/// Tries to write a simple EBML tag with a string value /// Tries to write a simple EBML tag with a string value
pub fn encode_string<T: Write>(tag: u64, string: &str, output: &mut T) -> IoResult<()> { pub fn encode_string<T: Write>(tag: u64, string: &str, output: &mut T) -> IoResult<()> {
encode_tag_header(tag, Varint::Value(string.len() as u64), output)?; encode_tag_header(tag, Varint::Value(string.len() as u64), output)?;
output.write_all(string.as_ref()).map(|()| string.len())?; output.write_all(string.as_ref())
Ok(()) }
} }
#[derive(Debug, PartialEq)] #[derive(Debug, PartialEq)]