commit | 73844cc7c8d2ec6edc9d4af6739adef336df60f1 | [log] [tgz] |
---|---|---|
author | Android Build Coastguard Worker <[email protected]> | Sat Oct 21 03:13:51 2023 +0000 |
committer | Android Build Coastguard Worker <[email protected]> | Sat Oct 21 03:13:51 2023 +0000 |
tree | 935b8af9ba613989a098688ec3ebb43d5737e071 | |
parent | a0a2c18f8cf945c12511e13618061ce511eac63c [diff] | |
parent | be6a6a333f77917fb865a7703258a7a66bfd763d [diff] |
Snap for 10985023 from be6a6a333f77917fb865a7703258a7a66bfd763d to 24Q1-release Change-Id: I6410e2ce15167c97fbb3440896a0f2ec8efbc002
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.