Name | Date | Size | #Lines | LOC | ||
---|---|---|---|---|---|---|
.. | - | - | ||||
src/ | 04-Jul-2025 | - | 868 | 561 | ||
.android-checksum.json | D | 04-Jul-2025 | 936 | 1 | 1 | |
.cargo-checksum.json | D | 04-Jul-2025 | 574 | 1 | 1 | |
Android.bp | D | 04-Jul-2025 | 934 | 37 | 33 | |
Cargo.toml | D | 04-Jul-2025 | 1.2 KiB | 48 | 42 | |
LICENSE | D | 04-Jul-2025 | 11.1 KiB | 203 | 169 | |
LICENSE-APACHE | D | 04-Jul-2025 | 11.1 KiB | 203 | 169 | |
METADATA | D | 04-Jul-2025 | 567 | 18 | 17 | |
MODULE_LICENSE_APACHE2 | D | 04-Jul-2025 | 0 | |||
README.md | D | 04-Jul-2025 | 1.3 KiB | 28 | 17 | |
cargo_embargo.json | D | 04-Jul-2025 | 51 | 4 | 4 |
README.md
1# BitReader 2 3BitReader is a helper type to extract strings of bits from a slice of bytes. 4 5[](https://crates.io/crates/bitreader) 6[](https://docs.rs/bitreader) 7[](https://github.com/irauta/bitreader/actions/workflows/rust.yml) 8 9Here is how you read first a single bit, then three bits and finally four bits from a byte buffer: 10 11 use bitreader::BitReader; 12 13 let slice_of_u8 = &[0b1000_1111]; 14 let mut reader = BitReader::new(slice_of_u8); 15 16 // You obviously should use try! or some other error handling mechanism here 17 let a_single_bit = reader.read_u8(1).unwrap(); // 1 18 let more_bits = reader.read_u8(3).unwrap(); // 0 19 let last_bits_of_byte = reader.read_u8(4).unwrap(); // 0b1111 20 21You can naturally read bits from longer buffer of data than just a single byte. 22 23As 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). 24 25## License 26 27Licensed under the Apache License, Version 2.0 or the MIT license, at your option. 28