14 releases (7 breaking)
new 0.8.0 | Jan 12, 2025 |
---|---|
0.7.1 | Dec 30, 2024 |
0.7.0 | Dec 29, 2023 |
0.6.2 | Sep 23, 2023 |
0.3.0 | Feb 27, 2022 |
#199 in Encoding
191 downloads per month
Used in 25 crates
(3 directly)
155KB
3K
SLoC
🗂️ type_reg
Serializable map of any type.
This library provides a map that can store any serializable type, and retrieve it as the strong type. Serialization and deserialization is also done without requiring the consumer to implement custom serde logic.
Usage
Add the following to Cargo.toml
type_reg = { version = "0.8.0", features = ["tagged"] }
type_reg = { version = "0.8.0", features = ["untagged"] }
# Values must impl Debug, and TypeMap's Debug impl will
# print the debug string of each value.
type_reg = { version = "0.8.0", features = ["debug"] }
# Use insertion order for TypeMap and TypeReg iteration order.
type_reg = { version = "0.8.0", features = ["ordered"] }
Untagged Type Registry
Serialization
use serde::{Deserialize, Serialize};
use type_reg::untagged::TypeMap;
#[derive(Clone, Copy, Debug, Deserialize, Serialize)]
struct A(u32);
fn main() {
let mut type_map = TypeMap::new();
type_map.insert("one", 1u32);
type_map.insert("two", 2u64);
type_map.insert("three", A(3));
println!("{}", serde_yaml::to_string(&type_map).unwrap());
// ---
// two: 2
// one: 1
// three: 3
}
Deserialization
use serde::{Deserialize, Serialize};
use type_reg::untagged::{TypeMap, TypeReg};
#[derive(Clone, Copy, Debug, Deserialize, Serialize)]
struct A(u32);
fn main() {
let mut type_reg = TypeReg::<String>::new();
type_reg.register::<u32>(String::from("one"));
type_reg.register::<u64>(String::from("two"));
type_reg.register::<A>(String::from("three"));
let serialized = "---\n\
one: 1\n\
two: 2\n\
three: 3\n\
";
let deserializer = serde_yaml::Deserializer::from_str(serialized);
let type_map: TypeMap<String> = type_reg.deserialize_map(deserializer).unwrap();
let data_u32 = type_map.get::<u32, _>("one").copied().unwrap();
let data_u64 = type_map.get::<u64, _>("two").copied().unwrap();
let data_a = type_map.get::<A, _>("three").copied().unwrap();
println!("{data_u32}, {data_u64}, {data_a:?}");
// 1, 2, A(3)
}
Tagged Type Registry
⚠️ Note: This uses std::any::type_name
internally, which is not stable.
Serialization
use serde::{Deserialize, Serialize};
use type_reg::tagged::TypeMap;
#[derive(Clone, Copy, Debug, Deserialize, Serialize)]
struct A(u32);
fn main() {
let mut type_map = TypeMap::new();
type_map.insert("one", 1u32);
type_map.insert("two", 2u64);
type_map.insert("three", A(3));
println!("{}", serde_yaml::to_string(&type_map).unwrap());
// ---
// one:
// u32: 1
// three:
// "rust_out::A": 3
// two:
// u64: 2
}
Deserialization
use serde::{Deserialize, Serialize};
use type_reg::tagged::{TypeMap, TypeReg};
#[derive(Clone, Copy, Debug, Deserialize, Serialize)]
struct A(u32);
fn main() {
let mut type_reg = TypeReg::new();
type_reg.register::<u32>();
type_reg.register::<u64>();
type_reg.register::<A>();
let serialized = "---\n\
one: { u32: 1 }\n\
two: { u64: 2 }\n\
three: { 'tagged_deserialize_map::A': 3 }\n\
";
let deserializer = serde_yaml::Deserializer::from_str(serialized);
let type_map: TypeMap<String> = type_reg.deserialize_map(deserializer).unwrap();
let data_u32 = type_map.get::<u32, _>("one").copied().unwrap();
let data_u64 = type_map.get::<u64, _>("two").copied().unwrap();
let data_a = type_map.get::<A, _>("three").copied().unwrap();
println!("{data_u32}, {data_u64}, {data_a:?}");
// 1, 2, A(3)
}
License
Licensed under either of
- Apache License, Version 2.0, (LICENSE-APACHE or https://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or https://opensource.org/licenses/MIT)
at your option.
Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.
Dependencies
~0.7–1.8MB
~38K SLoC