Crates.io Documentation Dependency status Build Status

bitstream_reader

Tools for reading data types of arbitrary bit length and might not be byte-aligned in the source data

The main way of handling with the binary data is to first create a BitBuffer ,wrap it into a BitStream and then read from the stream.

If performance is critical, working directly on the BitBuffer can be faster.

Once you have a BitStream, there are 2 different approaches of reading data

The BitRead and BitReadSized traits can be used with #[derive] if all fields implement BitRead or BitReadSized.

Examples

```rust use bitstream_reader::{BitBuffer, LittleEndian, BitStream, BitRead};

[derive(BitRead)]

struct ComplexType { first: u8, #[size = 15] second: u16, third: bool, }

fn main() { let bytes = vec![ 0b10110101, 0b01101010, 0b10101100, 0b10011001, 0b10011001, 0b10011001, 0b10011001, 0b11100111 ]; let buffer = BitBuffer::new(bytes, LittleEndian); let mut stream = BitStream::new(buffer); let value: u8 = stream.read_int(7)?; let complex: ComplexType = stream.read()?; } ```

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.