0.2.0 |
|
---|
#1126 在 #serde
21KB
388 行
serde-name
此包提供快速且可靠的方式来提取和覆盖 Rust 容器的 Serde 名称。
提取 Serde 名称
名称提取依赖于 Serde 的 Deserialize 特性
#[derive(Deserialize)]
struct Foo {
bar: Bar,
}
#[derive(Deserialize)]
#[serde(rename = "ABC")]
enum Bar { A, B, C }
assert_eq!(trace_name::<Foo>(), Some("Foo"));
assert_eq!(trace_name::<Bar>(), Some("ABC"));
assert_eq!(trace_name::<Option<Bar>>(), None);
覆盖 Serde 名称
SerializeNameAdapter
和 DeserializeNameAdapter
可用于在 #[serde(rename = "..")]
不够灵活的情况下覆盖容器的名称。
#[derive(Serialize, Deserialize)]
#[serde(remote = "Foo")] // Generates Foo::(de)serialize instead of implementing Serde traits.
struct Foo<T> {
data: T,
}
impl<'de, T> Deserialize<'de> for Foo<T>
where
T: Deserialize<'de>,
{
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
where
D: serde::de::Deserializer<'de>,
{
Foo::deserialize(DeserializeNameAdapter::new(
deserializer,
std::any::type_name::<Self>(),
))
}
}
impl<T> Serialize for Foo<T>
where
T: Serialize,
{
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where
S: serde::ser::Serializer,
{
Foo::serialize(
self,
SerializeNameAdapter::new(serializer, std::any::type_name::<Self>()),
)
}
}
// Testing the Deserialize implementation
assert!(trace_name::<Foo<u64>>().unwrap().ends_with("Foo<u64>"));
// Testing the Serialize implementation
use serde_reflection::*;
let mut tracer = Tracer::new(TracerConfig::default());
let mut samples = Samples::new();
let (mut ident, _) = tracer.trace_value(&mut samples, &Foo { data: 1u64 }).unwrap();
ident.normalize().unwrap();
assert!(matches!(ident, Format::TypeName(s) if s.ends_with("Foo<u64>")));
贡献
有关如何帮助的说明,请参阅 CONTRIBUTING 文件。
许可证
此项目可在 Apache 2.0 许可证或 MIT 许可证的条款下使用。
依赖项
~0.4–1MB
~24K SLoC