This crate helps serialize types as bytes and deserialize from bytes with a special byte order. This crate can be used in [no_std] environment and has no external dependencies.
If you are looking for a small universal binary (de)serializer that works with [serde], look at [bincode].
Main features:
* A clean way to convert structures to endians and back
* Derive
* no_std
and no external dependencies
```rust use endian_codec::{PackedSize, EncodeLE, DecodeLE}; // If you look at this structure without checking the documentation, you know it works with // little-endian notation
struct Version { major: u16, minor: u16, patch: u16 }
let mut buf = [0; Version::PACKEDLEN]; // From PackedSize let test = Version { major: 0, minor: 21, patch: 37 }; // if you work with big- and little-endians, you will not mix them accidentally test.encodeaslebytes(&mut buf); let testfromb = Version::decodefromlebytes(&buf); asserteq!(test, testfromb); ```
There can be also a situation when you are forced to work with mixed-endians in one struct. ```rust use endiancodec::{PackedSize, EncodeME}; // even if you only use derive EncodeME, you also need to have required traits in the scope. use endiancodec::{EncodeLE, EncodeBE}; // for #[endian = "le/be"]
// You work with a very old system and there are mixed-endians // There will be only one format "le" or "little" in the next minor version. struct Request { #[endian = "le"] cmd: u16, #[endian = "little"] // or #[endian = "le"] value: i64, #[endian = "big"] // or #[endian = "be"] timestamp: i128, }
let mut buf = [0; Request::PACKEDLEN]; let req = Request { cmd: 0x44, value: 74, timestamp: 0xFFFFFFFF00000000, }; // here we see me (mixed-endian), just look at the struct definition for details req.encodeasme_bytes(&mut buf);
```
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.
This project try follow rules: * Keep a Changelog, * Semantic Versioning.
This README was generated with cargo-readme from template