зеркало из https://github.com/mozilla/gecko-dev.git
6ec77fef76
Also update the update-rust.sh script in a couple ways: - Stop copying the source for mp4parse_fallible into the tree; use crates.io - Include submodules in mp4parse-rust checkout; needed for tests - Exclude unnecessary build.rs from mp4parse_fallible, it was causing problems - Update mp4rust_capi/Cargo.toml patch to exclude cdylib. It's only necessary for test_ffi and causes build problems otherwise Differential Revision: https://phabricator.services.mozilla.com/D68139 --HG-- extra : moz-landing-system : lando |
||
---|---|---|
.. | ||
src | ||
.cargo-checksum.json | ||
Cargo.toml | ||
LICENSE-APACHE | ||
LICENSE-MIT | ||
README.md |
README.md
BitReader
BitReader is a helper type to extract strings of bits from a slice of bytes.
Here is how you read first a single bit, then three bits and finally four bits from a byte buffer:
use bitreader::BitReader;
let slice_of_u8 = &[0b1000_1111];
let mut reader = BitReader::new(slice_of_u8);
// You obviously should use try! or some other error handling mechanism here
let a_single_bit = reader.read_u8(1).unwrap(); // 1
let more_bits = reader.read_u8(3).unwrap(); // 0
let last_bits_of_byte = reader.read_u8(4).unwrap(); // 0b1111
You can naturally read bits from longer buffer of data than just a single byte.
As you read bits, the internal cursor of BitReader moves on along the stream of bits. Big endian format is assumed when reading the multi-byte values. BitReader supports reading maximum of 64 bits at a time (with read_u64).
License
Licensed under the Apache License, Version 2.0 or the MIT license, at your option.