23 releases

0.7.44 Feb 4, 2024
0.7.43 Dec 17, 2023
0.7.42 May 13, 2023
0.7.41 Mar 31, 2023
0.2.0 Nov 19, 2020

#2128 in Encoding

Download history 737/week @ 2024-12-15 780/week @ 2024-12-22 368/week @ 2024-12-29 619/week @ 2025-01-05 327/week @ 2025-01-12 351/week @ 2025-01-19 145/week @ 2025-01-26 326/week @ 2025-02-02 566/week @ 2025-02-09 393/week @ 2025-02-16 548/week @ 2025-02-23 226/week @ 2025-03-02 389/week @ 2025-03-09 271/week @ 2025-03-16 146/week @ 2025-03-23 387/week @ 2025-03-30

1,287 downloads per month
Used in 23 crates (2 directly)

MIT license

12KB
201 lines

rkyv_typename adds type names for rkyv_dyn.

Resources

Learning Materials

  • The rkyv book covers the motivation, architecture, and major features of rkyv
  • The rkyv discord is a great place to get help with specific issues and meet other people using rkyv

Documentation

Benchmarks

  • The rust serialization benchmark is a shootout style benchmark comparing many rust serialization solutions. It includes special benchmarks for zero-copy serialization solutions like rkyv.

Sister Crates

  • bytecheck, which rkyv uses for validation
  • ptr_meta, which rkyv uses for pointer manipulation
  • rend, which rkyv uses for endian-agnostic features

Example

use rkyv_typename::TypeName;

#[derive(TypeName)]
#[typename = "CoolType"]
struct Example<T>(T);

fn main() {
    let mut type_name = String::new();
    Example::<i32>::build_type_name(|piece| type_name += piece);
    assert_eq!(type_name, "CoolType<i32>");
}

Dependencies

~1.5MB
~37K SLoC