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
read_bool
], [read_int
], [read_float
], [read_bytes
] and [read_string
]BitRead
] or [BitReadSized
] traits using [read
] and [read_sized
]
BitRead
] is for types that can be read without requiring any size info (e.g. null-terminal strings, floats, whole integers, etc)BitReadSized
] is for types that require external sizing information to be read (fixed length strings, arbitrary length integersThe [BitRead
] and [BitReadSized
] traits can be used with #[derive]
if all fields implement [BitRead
] or [BitReadSized
].
```rust use bitbuffer::{BitReadBuffer, LittleEndian, BitReadStream, 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()?; ```
Licensed under either of
at your option.
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.