Crates.io | endi |
lib.rs | endi |
version | 1.1.0 |
source | src |
created_at | 2023-12-10 18:57:15.997741 |
updated_at | 2023-12-12 12:27:19.244448 |
description | A simple endian-handling library |
homepage | |
repository | https://github.com/zeenix/endi |
max_upload_size | |
id | 1064452 |
size | 17,680 |
Yet another endian handling library for Rust. The approach is very similar to that of
byteordered
crate with its Endianness
enum, except that endi
is much simpler and doesn't
depend on byteorder
(or anything at all).
The main type is Endian
enum which can be either Big
or Little
. It provides various
methods to read and write integers of different sizes and endianness.
use endi::{Endian, ReadBytes, WriteBytes};
let mut buf = [0u8; 4];
for endian in [Endian::Little, Endian::Big] {
endian.write_u32(&mut buf, 0xAB_BA_FE_EF);
assert_eq!(endian.read_u32(&buf), 0xAB_BA_FE_EF);
// Using the `ReadBytes` and `WriteBytes` traits:
let mut cursor = std::io::Cursor::new(&mut buf[..]);
cursor.write_u32(endian, 0xAB_BA_FE_EF).unwrap();
cursor.set_position(0);
assert_eq!(cursor.read_u32(endian).unwrap(), 0xAB_BA_FE_EF);
}
You can disable std
by disabling the default std
feature. This will disable the ReadBytes
and
WriteBytes
traits.