Expand description
§endi
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).
§Usage
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);
}§nostd
You can disable std by disabling the default std feature. This will disable the ReadBytes and
WriteBytes traits.
§License
Enums§
- Endian
- The endian of the data.
Constants§
- BE
- Alias for
Endian::Big. - LE
- Alias for
Endian::Little. - NATIVE_
ENDIAN - Same as the return value of
Endian::native. - NETWORK_
ENDIAN - Alias for
Endian::Big.
Traits§
- Read
Bytes - A trait for reading bytes.
- Write
Bytes - A trait for writing bytes.