Crates.io Documentation Dependency status

bitbuffer

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.

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 bitbuffer::{BitReadBuffer, LittleEndian, BitReadStream, BitRead};

[derive(BitRead)]

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

let bytes = vec![ 0b10110101, 0b01101010, 0b10101100, 0b10011001, 0b10011001, 0b10011001, 0b10011001, 0b11100111 ]; let buffer = BitReadBuffer::new(bytes, LittleEndian); let mut stream = BitReadStream::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.