【发布时间】:2019-10-23 23:37:34
【问题描述】:
我有一个由其他枚举组成的枚举,类似于以下内容(为简洁起见,serde 派生和注释省略):
enum Main {
A(SubA),
B(SubB),
}
enum SubA { X1, X2, X3 }
enum SubB { Y1, Y2, Y3 }
我希望能够使用serde 反序列化诸如“X1”或“Y3”之类的字符串,并分别自动返回Main::A(SubA::X1) 或Main::B(SubB::Y3)。
我了解serde 支持新类型样式结构上的#[serde(transparent)] 属性,这可以做我喜欢的事情。但是,它似乎只适用于结构或枚举级别,而不是枚举变量级别。有没有一种方法可以自动获得我正在寻找的行为?我可以确保任何包含的子枚举中的任何变体名称都不会重叠。
除了希望保持 Rust 2018 稳定之外,我对我的项目没有其他限制,并且我愿意接受任何有用的 crate 建议。
【问题讨论】:
-
我认为没有任何开箱即用的方法。您可以尝试手动实现反序列化和序列化,如示例serde.rs/custom-serialization.html
-
@Stargateur 问题中已经有关于OP想要什么的例子。具体来说,如果输入是字符串
X1,输出应该是Main::A (SubA::X1),如果输入是Y3,输出应该是Main::B (SubB::Y3)... -
我不确定
serde是否开箱即用地实现了这一点,因为当您有一个枚举在不同变体中保存相同类型时似乎很难做到(即enum Main{A(SubA), B(SubA)}。应该@ 987654335@ 然后被反序列化为?(如果SubA和SubB都包含变体X1,则会出现类似问题。)