Expand description
Crate castflip is a Rust library for encoding and decoding numeric variables, arrays and structures in little-endian and big-endian. It provides methods to convert between a byte representation of a format and a value of a Rust type with endianness handling.
§Introduction
Crate castflip provides several traits
- to encast a byte representation of a type as a value of the type,
- to decast a value of a type as a byte representation of the type, and
- to flip the endianness of a value of a type as required.
The supported types include
- primitive numeric types, and
- array types,
structtypes anduniontypes consisting of the supported types.
§A Simple Example
The example below encasts a byte representation of the UDP1
header in big-endian as a value of a struct type in native-endian.
use castflip::{BE, Cast, EncastMem, Flip};
//
// Step 1: Define struct `UdpHdr`.
//
#[repr(C)] // to make it possible to apply #[derive(Cast)]
#[derive(Cast, Flip)] // to implement trait Cast and trait Flip
struct UdpHdr { // UDP: See https://www.rfc-editor.org/rfc/rfc768.txt
sport: u16, // UDP Source Port
dport: u16, // UDP Destination Port
len: u16, // UDP Length in Bytes (header plus data)
sum: u16, // UDP Checksum
}
//
// Step 2: Encast a byte representation of the UDP header in big-endian
// (`BE`) stored in variable `in_bytes` as a value of struct `UdpHdr` in
// native-endian and save it to variable `out_hdr`.
//
// Input: A sample byte representation of the UDP header (8 bytes)
let in_bytes: [u8; 8] = [0xc3, 0xc9, 0x00, 0x35, 0x00, 0x32, 0x82, 0x3f];
// Encast a byte representation in big-endian (`BE`) as a value.
let out_hdr: UdpHdr = in_bytes.encastf(BE).unwrap();
// Check if all fields in variable `out_hdr` are as expected.
assert_eq!(out_hdr.sport, 0xc3c9); // = 50121 (Ephemeral Port)
assert_eq!(out_hdr.dport, 0x0035); // = 53 (DNS Port)
assert_eq!(out_hdr.len, 0x0032); // = 50 (Length in Bytes)
assert_eq!(out_hdr.sum, 0x823f); // = 0x823f (Checksum)§Dependencies
To use crate castflip version 0.1, add the following lines to your
Cargo.toml:
[dependencies]
castflip = "0.1"§Documents
The documents below describes the API of the castflip crate version 0.1.
Short Examples as a Quick Start Guide:
- How to convert between bytes and a number
- How to convert between bytes and an array of numbers
- How to convert between bytes and a
struct - How to convert between bytes and an array of
structs
Long Examples with Explanations:
- How to convert between bytes and a
struct(The UDP header) - How to convert between bytes and a nested
struct - How to convert between bytes and an array of
structs - How to convert between bytes and a
struct(The UDP header) usingstd::io
Summaries of Types, Traits, Crate Features, etc.:
Modules§
- documents
- The documents directory
- experimental
- Defines experimental traits and historical traits.
Enums§
- Endian
- Defines two types of endiannesses: Relative Endiannesses (Native and Swapped) and Absolute Endiannesses (Little and Big).
Constants§
- BE
- Is an alias of
Endian::Big.BEstands for the Big Endianness. - LE
- Is an alias of
Endian::Little.LEstands for the Little Endianness. - NE
- Is an alias of
Endian::Native.NEstands for the Native Endianness. - SE
- Is an alias of
Endian::Swapped.SEstands for the Swapped Endianness.
Traits§
- Cast
- Marks types whose values can be encasted and decasted by the methods of this crate.
- DecastIO
- Provides methods that decast one or more values of a type
specified by a parameter as one or more byte representations of the
type and write the resulting byte representations to writer
selfusing traitstd::io::Write. - Decast
Mem - Provides methods that decast one or more values of a type
specified by a parameter as one or more byte representations of the
type and save the resulting byte representations at the head of byte
slice specified by
self. - EncastIO
- Provides methods that encast one or more byte representations
of a type read from reader
selfusing traitstd::io::Readas one or more values of the type and return the resulting values. - Encast
Mem - Provides methods that encast one or more byte representations
of a type at the head of a byte slice specified by
selfas one or more values of the type and return the resulting values. - Flip
- Marks types whose values’ endiannesses can be flipped by the methods of this crate.
- NopFlip
- Marks types that implement trait
Flipwhose methods do nothing.