serde-scale

Crates.ioserde-scale
lib.rsserde-scale
version0.2.2
sourcesrc
created_at2020-10-07 07:00:27.647116
updated_at2020-10-15 20:58:10.523005
descriptionSerde serializer and deserializer for the SCALE encoding
homepagehttps://github.com/stephaneyfx/serde-scale
repositoryhttps://github.com/stephaneyfx/serde-scale.git
max_upload_size
id296856
size52,657
crate-publishers (github:osmosis-labs:crate-publishers)

documentation

README

Overview

Serializer and deserializer for the SCALE encoding based on serde.

Example

use serde::{Deserialize, Serialize};

#[derive(Debug, Deserialize, PartialEq, Serialize)]
struct Point {
    x: i8,
    y: i8,
}

let point = Point { x: 3, y: 4 };
let deserialized = serde_scale::from_slice(&serde_scale::to_vec(&point).unwrap()).unwrap();
assert_eq!(point, deserialized);

Conformance

Option<bool> is serialized as a single byte according to the SCALE encoding.

Features

no_std is supported by disabling default features.

  • std: Support for std. It is enabled by default.
  • alloc: Support for the alloc crate.

🔖 Features enabled in build dependencies and proc-macros are also enabled for normal dependencies, which may cause serde to have its std feature on when it is not desired. Nightly cargo prevents this from happening with -Z features=host_dep or the following in .cargo/config:

[unstable]
features = ["host_dep"]

For example, this issue arises when depending on parity-scale-codec-derive.

Test

Most tests live in the serde-scale-tests crate (part of the workspace) in order to avoid dependencies enabling serde features.

cargo test --workspace

Contribute

All contributions shall be licensed under the zlib license.

Related projects

parity-scale-codec: Reference Rust implementation

Commit count: 6

cargo fmt