#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

#17 in #rlp

Download history 80/week @ 2024-07-22 85/week @ 2024-07-29 114/week @ 2024-08-05 82/week @ 2024-08-12 71/week @ 2024-08-19 100/week @ 2024-08-26 74/week @ 2024-09-02 52/week @ 2024-09-09 69/week @ 2024-09-16 107/week @ 2024-09-23 48/week @ 2024-09-30 5/week @ 2024-10-07 73/week @ 2024-10-14 61/week @ 2024-10-21 63/week @ 2024-10-28 84/week @ 2024-11-04

281 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

~130KB