commit | e979cb0394fdd8b3c58a9fc60ae1ddebd78b51d5 | [log] [tgz] |
---|---|---|
author | Elie Kheirallah | Sat Nov 05 09:00:27 2022 +0000 |
committer | Automerger Merge Worker | Sat Nov 05 09:00:27 2022 +0000 |
tree | 49519c029bf676f9b8f4d7c0a7dc79fb77cd0a9f | |
parent | b034c8fb1eda56588fcfe6afa9e3db521e1c9f4f [diff] | |
parent | 7fe620bc547000427cfae5a45b05e0364713bd94 [diff] |
Initial import of bitreader-0.3.6 am: 7016150b58 am: ec3462a199 am: 7fe620bc54 Original change: https://android-review.googlesource.com/c/platform/external/rust/crates/bitreader/+/2287737 Change-Id: I4f0ae879dd1fd9e1c3e512fb790c66b93531b59b Signed-off-by: Automerger Merge Worker
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).
Licensed under the Apache License, Version 2.0 or the MIT license, at your option.