Expand description
§alloy-rlp
This crate provides Ethereum RLP (de)serialization functionality. RLP is commonly used for Ethereum EL datastructures, and its documentation can be found at ethereum.org.
§Usage
We strongly recommend deriving RLP traits via the RlpEncodable
and
RlpDecodable
derive macros.
Trait methods can then be accessed via the Encodable
and Decodable
traits.
§Example
use alloy_rlp::{RlpEncodable, RlpDecodable, Decodable, Encodable};
#[derive(Debug, RlpEncodable, RlpDecodable, PartialEq)]
pub struct MyStruct {
pub a: u64,
pub b: Vec<u8>,
}
let my_struct = MyStruct {
a: 42,
b: vec![1, 2, 3],
};
let mut buffer = Vec::<u8>::new();
let encoded = my_struct.encode(&mut buffer);
let decoded = MyStruct::decode(&mut buffer.as_slice()).unwrap();
assert_eq!(my_struct, decoded);
Re-exports§
pub use bytes;
pub use bytes::Buf;
pub use bytes::BufMut;
pub use bytes::Bytes;
pub use bytes::BytesMut;
Macros§
- Implement
MaxEncodedLen
andMaxEncodedLenAssoc
for a type.
Structs§
- The header of an RLP item.
- An active RLP decoder, with a specific slice of a payload.
Enums§
- RLP error type.
- Structured representation of an RLP payload.
Constants§
- RLP prefix byte for a 0-length array.
- RLP prefix byte for 0-length string.
Traits§
- A type that can be decoded from an RLP blob.
- A type that can be encoded via RLP.
- Defines the max length of an
Encodable
type as a const generic. - Defines the max length of an
Encodable
type as an associated constant.
Functions§
- Decodes the entire input, ensuring no trailing bytes remain.
- Encode a value.
- Encode all items from an iterator.
- Encode a list of items.
- Determine the length in bytes of the length prefix of an RLP item.
- Calculate the length of a list.
Type Aliases§
- RLP result type.
Derive Macros§
- Derives
Decodable
for the type whose implementation expects an rlp-list input:<rlp-header, fields...>
- Derives
Decodable
for the type whose implementation expects only the individual fields encoded:<fields...>
- Derives
Encodable
for the type which encodes the all fields as list:<rlp-header, fields...>
- Derives
Encodable
for thenewtype
which encodes its single field as-is, without a header:<field>
- Derives
MaxEncodedLen
for types of constant size.