#endian #byteorder #order #byte #defined #type #default

no-std endian-type-rs

Type safe wrappers for types with a defined byte order

2 releases

Uses old Rust 2015

0.1.4 May 28, 2020
0.1.3 May 28, 2020

#776 in Embedded development

Download history 276/week @ 2024-04-15 342/week @ 2024-04-22 295/week @ 2024-04-29 434/week @ 2024-05-06 212/week @ 2024-05-13 130/week @ 2024-05-20 328/week @ 2024-05-27 319/week @ 2024-06-03 220/week @ 2024-06-10 255/week @ 2024-06-17 1060/week @ 2024-06-24 991/week @ 2024-07-01 190/week @ 2024-07-08 296/week @ 2024-07-15 302/week @ 2024-07-22 115/week @ 2024-07-29

915 downloads per month
Used in 2 crates (via fdt-rs)

MIT license

9KB
181 lines

endian-type-rs

A fork of endian-type which includes support for no-std and the From trait.

Usage

Add this to your Cargo.toml:

[dependencies.endian-type-rs]
version = "0.1.4"

and this to your crate root:

extern crate endian_type_rs;

Features

This crate can be used without the standard library (#![no_std]) by disabling the default std feature. Use this in Cargo.toml:

[dependencies.endian-type-rs]
version = "0.1.4"
default-features = false
# features = ["num"]    # <--- Uncomment if you wish to include support for num::ToPrimitive

The "num" feature will add additional definitions for simplified casting via the num crate "num".

Previously casting between the internal types and another built-in numeric type required a decent amount of boilerplate. In the worst case you needed to specify both the current Big/LittleEndian's underlying type as well as the type you were trying to cast to. E.g.

let val: u32_be = u32_be::from(10);
let addr = u32::from(val) as usize;

This isn't much overhead here where the type is obvious, however if you change the underlying type of "val" in the above example, you must change every single cast. Now the above becomes:

let val: u32_be = u32_be::from(10);
let addr = val.to_usize().unwrap();

Dependencies

~73KB