commit | bf8d2e8805a84b1f8111319fea048dd35ab5926b | [log] [tgz] |
---|---|---|
author | Android Build Coastguard Worker <[email protected]> | Sun Aug 25 07:08:21 2024 +0000 |
committer | Android Build Coastguard Worker <[email protected]> | Sun Aug 25 07:08:21 2024 +0000 |
tree | 1c8eccc36849e2176abb7483e40b791c3bceb6fe | |
parent | 62c6fa299362bdc4117c941d2504ae7a3ce11fa9 [diff] | |
parent | 68fde2fbe6d80283770defc7b41268c9e0c0b7e4 [diff] |
Snap for 12261761 from 68fde2fbe6d80283770defc7b41268c9e0c0b7e4 to busytown-mac-infra-release Change-Id: I71f9012bf6f758581cc44716d0174f9aa1e6a162
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.