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 |
#1543 in Encoding
3,196 downloads per month
Used in 23 crates
(2 directly)
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
- rkyv, the core library
- rkyv_dyn, which adds trait object support to rkyv
- rkyv_typename, a type naming library
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