#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 39/week @ 2024-01-28 80/week @ 2024-02-04 78/week @ 2024-02-11 99/week @ 2024-02-18 98/week @ 2024-02-25 90/week @ 2024-03-03 106/week @ 2024-03-10 106/week @ 2024-03-17 147/week @ 2024-03-24 197/week @ 2024-03-31 89/week @ 2024-04-07 153/week @ 2024-04-14 157/week @ 2024-04-21 110/week @ 2024-04-28 118/week @ 2024-05-05 127/week @ 2024-05-12

521 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