Bug: 257493050

Clone this repo:
  1. 91fdb20 Upgrade bitreader to 0.3.8 am: badce51236 by Jeff Vander Stoep · 3 months ago main master
  2. badce51 Upgrade bitreader to 0.3.8 by Jeff Vander Stoep · 3 months ago
  3. be6a6a3 Migrate to cargo_embargo. am: 88037d1910 am: f380c619e2 am: 09b58a7d12 by Andrew Walbran · 7 months ago
  4. 09b58a7 Migrate to cargo_embargo. am: 88037d1910 am: f380c619e2 by Andrew Walbran · 7 months ago
  5. 22f0cec Migrate to cargo_embargo. am: 88037d1910 am: 527dec1d25 am: 30129f13a7 by Andrew Walbran · 7 months ago

BitReader

BitReader is a helper type to extract strings of bits from a slice of bytes.

Published Package Documentation Build Status

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.