bytesparser ![CIs] ![Docs] ![Vers] ![Downs] ![Lics]

A simple wrapper to parse primitive Rust types from a slice of bytes [u8]


What is it for?

This is the crate for you, if all you need is to parse a bespoke binary protocol. You provide a reference slice of bytes, and assuming you know what those bytes represent, read the original values out of it.

The core of this crate is BytesParser, built with few principles in mind:

Features

Examples

```rust use bytes_parser::{BytesParser, ParsingEndian};

let input: &[u8] = /* a slice of bytes from somewhere */;

// Crate a parser from a given slice of bytes let mut parser = BytesParser::from(input);

// Will use Big-Endian parsing asserteq!(parser.endian(), ParsingEndian::BE); asserteq!(ParsingEndian::BE, ParsingEndian::default());

// Parse a string length and the string itself let strlen = parser.parseusize()?; let str = parser.parsestrutf8(strlen)?; asserteq!(str, "Forza Napoli Sempre!"); ```

Alternatives

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.