#decode #encode #deserialize #serialization #binary #binary-encode

macro cu-bincode-derive

Implementation of #[derive(Encode, Decode)] for bincode

1 stable release

Uses new Rust 2024

2.0.2 Dec 22, 2025

#11 in #binary-encode

Download history 96/week @ 2025-12-21 235/week @ 2025-12-28 551/week @ 2026-01-04 1535/week @ 2026-01-11 2037/week @ 2026-01-18 1097/week @ 2026-01-25 484/week @ 2026-02-01 669/week @ 2026-02-08 676/week @ 2026-02-15 4139/week @ 2026-02-22

6,020 downloads per month
Used in 62 crates (via cu-bincode)

MIT license

45KB
780 lines

cu-bincode-derive

This is a hard fork of bincode 2 (2.0.1) from crates.io (see first verbatim commit). Do not contact the original authors as per their wishes.

The derive crate for cu-bincode. Implements cu_bincode::Encode and cu_bincode::Decode.

This crate is roughly split into 2 parts:

Parsing

Most of parsing is done in the src/parse/ folder. This will generate the following types:

  • Attributes, not being used currently
  • Visibility, not being used currently
  • DataType either Struct or Enum, with the name of the data type being parsed
  • Generics the generics part of the type, e.g. struct Foo<'a>
  • GenericConstraints the "where" part of the type

Generate

Generating the code implementation is done in either src/derive_enum.rs and src/derive_struct.rs.

This is supported by the structs in src/generate. The most notable points of this module are:

  • StreamBuilder is a thin but friendly wrapper around TokenStream
  • Generator is the base type of the code generator. This has helper methods to generate implementations:
    • ImplFor is a helper struct for a single impl A for B construction. In this functions can be defined:
      • GenerateFnBody is a helper struct for a single function in the above impl. This is created with a callback to FnBuilder which helps set some properties. GenerateFnBody has a stream() function which returns StreamBuilder for the function.

For additional derive testing, see the test cases in ../tests

For testing purposes, all generated code is outputted to the current target/generated/cu_bincode folder, under file name <struct/enum name>_Encode.rs and <struct/enum name>_Decode.rs. This can help with debugging.

Dependencies

~185KB