#serialization #no-std

no-std sval_derive

Derive support for sval

49 releases (18 stable)

new 2.9.1 Sep 29, 2023
2.6.1 Jun 27, 2023
2.0.2 Mar 24, 2023
1.0.0-alpha.5 Jan 27, 2021
0.0.4 Dec 6, 2018

#181 in #serialization

Download history 455/week @ 2023-06-09 570/week @ 2023-06-16 525/week @ 2023-06-23 603/week @ 2023-06-30 564/week @ 2023-07-07 508/week @ 2023-07-14 490/week @ 2023-07-21 493/week @ 2023-07-28 477/week @ 2023-08-04 604/week @ 2023-08-11 656/week @ 2023-08-18 716/week @ 2023-08-25 519/week @ 2023-09-01 529/week @ 2023-09-08 620/week @ 2023-09-15 509/week @ 2023-09-22

2,266 downloads per month
Used in 2 crates (via log)

Apache-2.0 OR MIT

38KB
871 lines

sval_derive

Rust Latest version Documentation Latest

Automatically derive sval::Value.


lib.rs:

#![derive(Value)].

This library hosts a custom-derive to simplify implementing sval::Value.

Structs

Container attributes:

  • #[sval(tag = "path::to::TAG")]: Set a tag on the struct. No tag is used by default.
  • #[sval(label = "text")]: Set a label on the struct. The identifier of the struct is used by default.
  • #[sval(index = 1)]: Set an index on the struct. No index is used by default.
  • #[sval(unlabeled_fields)]: Specify that all fields should be unlabeled. This will stream the struct as a tuple. If #[sval(unindexed_fields)] is also specified then it will stream the struct as a sequence.
  • #[sval(unindexed_fields]: Specify that all fields should be unindexed. This will stream the struct as a record. If #[sval(unlabeled_fields)] is also specified then it will stream the struct as a sequence.

Field attributes:

  • #[sval(tag = "path::to::TAG")]: Set a tag on the struct field itself. No tag is used by default. If you want to use a tag to signal that the field's value has a particular property then use #[sval(data_tag)].
  • #[sval(data_tag = "path::to::TAG")]: Set a tag on the struct field's value. No tag is used by default.
  • #[sval(label = "text")]: Set a label on the struct field. The identifier of the field is used by default.
  • #[sval(index = 1)]: Set an index on the struct field. The zero-based offset of the field is used by default.
  • #[sval(skip)]: Skip a field.
  • #[sval(flatten)]: Flatten the field onto the struct. This attribute requires the flatten Cargo feature.

Newtypes

Container attributes:

  • #[sval(tag = "path::to::TAG")]: Set a tag on the newtype. No tag is used by default.
  • #[sval(label = "text")]: Set a label on the newtype. The identifier of the newtype is used by default.
  • #[sval(index = 1)]: Set an index on the newtype. No index is used by default.
  • #[sval(transparent)]: Stream the newtype as its underlying field without wrapping it.

Enums

Container attributes:

  • #[sval(tag = "path::to::TAG")]: Set a tag on the enum. No tag is used by default.
  • #[sval(label = "text")]: Set a label on the enum. The identifier of the enum is used by default.
  • #[sval(index = 1)]: Set an index on the enum. No index is used by default.
  • #[sval(dynamic)]: Stream the variant without wrapping it in an enum.

Variant attributes:

  • #[sval(tag = "path::to::TAG")]: Set a tag on the enum variant itself. No tag is used by default.
  • #[sval(label = "text")]: Set a label on the enum variant. The identifier of the variant is used by default.
  • #[sval(index = 1)]: Set an index on the enum variant. The zero-based offset of the variant is used by default.

Dependencies

~330–800KB
~20K SLoC