#ethereum #rlp #codec #no-std #decoding #prefix #compression

no-std ethereum-rlp

Recursive-length prefix encoding, decoding, and compression

1 unstable release

Uses old Rust 2015

0.2.3 Dec 11, 2017

#14 in #rlp

Download history 49/week @ 2023-11-30 83/week @ 2023-12-07 103/week @ 2023-12-14 86/week @ 2023-12-21 49/week @ 2023-12-28 70/week @ 2024-01-04 111/week @ 2024-01-11 75/week @ 2024-01-18 53/week @ 2024-01-25 34/week @ 2024-02-01 80/week @ 2024-02-08 107/week @ 2024-02-15 105/week @ 2024-02-22 88/week @ 2024-02-29 109/week @ 2024-03-07 74/week @ 2024-03-14

382 downloads per month
Used in 34 crates (15 directly)

MIT/Apache

60KB
1K SLoC

RLP

Recursive-length-prefix encoding, decoding, and compression in Rust.

License

Unlike most parts of Parity, which fall under the GPLv3, this package is dual-licensed under MIT/Apache2 at the user's choice. Find the associated license files in this directory as LICENSE-MIT and LICENSE-APACHE2 respectively.


lib.rs:

Recursive Length Prefix serialization crate.

Allows encoding, decoding, and view onto rlp-slice

What should you use when?

Use encode function when:

  • You want to encode something inline.
  • You do not work on big set of data.
  • You want to encode whole data structure at once.

Use decode function when:

  • You want to decode something inline.
  • You do not work on big set of data.
  • You want to decode whole rlp at once.

Use RlpStream when:

  • You want to encode something in portions.
  • You encode a big set of data.

Use Rlp when:

  • You are working on trusted data (not corrupted).
  • You want to get view onto rlp-slice.
  • You don't want to decode whole rlp at once.

Use UntrustedRlp when:

  • You are working on untrusted data (~corrupted).
  • You need to handle data corruption errors.
  • You are working on input data.
  • You want to get view onto rlp-slice.
  • You don't want to decode whole rlp at once.

Dependencies

~135KB