crates.io Documentation CI master Maintenance derive: crates.io

endian_codec

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

Examples

```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

[derive(Debug, PartialEq, Eq, PackedSize, EncodeLE, DecodeLE)]

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"]

[derive(PackedSize, EncodeME)]

// 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);

```

Why another crate to handle endians?

There are a few other crates that deal with endians:

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.

This project try follow rules: * Keep a Changelog, * Semantic Versioning.

This README was generated with cargo-readme from template