nominal_api/conjure/objects/scout/chartdefinition/api/
enum_display_style.rs1use conjure_object::serde::{ser, de};
2use conjure_object::serde::ser::SerializeMap as SerializeMap_;
3use conjure_object::private::{UnionField_, UnionTypeField_};
4use std::fmt;
5#[derive(Debug, Clone, PartialEq, Eq, PartialOrd, Ord, Hash)]
6pub enum EnumDisplayStyle {
7 Stacked(super::EnumDisplayStyleStacked),
8 Inline(super::EnumDisplayStyleInline),
9 Bar(super::EnumDisplayStyleBar),
10 Line(super::EnumDisplayStyleLine),
11 Unknown(Unknown),
13}
14impl ser::Serialize for EnumDisplayStyle {
15 fn serialize<S>(&self, s: S) -> Result<S::Ok, S::Error>
16 where
17 S: ser::Serializer,
18 {
19 let mut map = s.serialize_map(Some(2))?;
20 match self {
21 EnumDisplayStyle::Stacked(value) => {
22 map.serialize_entry(&"type", &"stacked")?;
23 map.serialize_entry(&"stacked", value)?;
24 }
25 EnumDisplayStyle::Inline(value) => {
26 map.serialize_entry(&"type", &"inline")?;
27 map.serialize_entry(&"inline", value)?;
28 }
29 EnumDisplayStyle::Bar(value) => {
30 map.serialize_entry(&"type", &"bar")?;
31 map.serialize_entry(&"bar", value)?;
32 }
33 EnumDisplayStyle::Line(value) => {
34 map.serialize_entry(&"type", &"line")?;
35 map.serialize_entry(&"line", value)?;
36 }
37 EnumDisplayStyle::Unknown(value) => {
38 map.serialize_entry(&"type", &value.type_)?;
39 map.serialize_entry(&value.type_, &value.value)?;
40 }
41 }
42 map.end()
43 }
44}
45impl<'de> de::Deserialize<'de> for EnumDisplayStyle {
46 fn deserialize<D>(d: D) -> Result<EnumDisplayStyle, D::Error>
47 where
48 D: de::Deserializer<'de>,
49 {
50 d.deserialize_map(Visitor_)
51 }
52}
53struct Visitor_;
54impl<'de> de::Visitor<'de> for Visitor_ {
55 type Value = EnumDisplayStyle;
56 fn expecting(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
57 fmt.write_str("union EnumDisplayStyle")
58 }
59 fn visit_map<A>(self, mut map: A) -> Result<EnumDisplayStyle, A::Error>
60 where
61 A: de::MapAccess<'de>,
62 {
63 let v = match map.next_key::<UnionField_<Variant_>>()? {
64 Some(UnionField_::Type) => {
65 let variant = map.next_value()?;
66 let key = map.next_key()?;
67 match (variant, key) {
68 (Variant_::Stacked, Some(Variant_::Stacked)) => {
69 let value = map.next_value()?;
70 EnumDisplayStyle::Stacked(value)
71 }
72 (Variant_::Inline, Some(Variant_::Inline)) => {
73 let value = map.next_value()?;
74 EnumDisplayStyle::Inline(value)
75 }
76 (Variant_::Bar, Some(Variant_::Bar)) => {
77 let value = map.next_value()?;
78 EnumDisplayStyle::Bar(value)
79 }
80 (Variant_::Line, Some(Variant_::Line)) => {
81 let value = map.next_value()?;
82 EnumDisplayStyle::Line(value)
83 }
84 (Variant_::Unknown(type_), Some(Variant_::Unknown(b))) => {
85 if type_ == b {
86 let value = map.next_value()?;
87 EnumDisplayStyle::Unknown(Unknown { type_, value })
88 } else {
89 return Err(
90 de::Error::invalid_value(de::Unexpected::Str(&type_), &&*b),
91 )
92 }
93 }
94 (variant, Some(key)) => {
95 return Err(
96 de::Error::invalid_value(
97 de::Unexpected::Str(key.as_str()),
98 &variant.as_str(),
99 ),
100 );
101 }
102 (variant, None) => {
103 return Err(de::Error::missing_field(variant.as_str()));
104 }
105 }
106 }
107 Some(UnionField_::Value(variant)) => {
108 let value = match &variant {
109 Variant_::Stacked => {
110 let value = map.next_value()?;
111 EnumDisplayStyle::Stacked(value)
112 }
113 Variant_::Inline => {
114 let value = map.next_value()?;
115 EnumDisplayStyle::Inline(value)
116 }
117 Variant_::Bar => {
118 let value = map.next_value()?;
119 EnumDisplayStyle::Bar(value)
120 }
121 Variant_::Line => {
122 let value = map.next_value()?;
123 EnumDisplayStyle::Line(value)
124 }
125 Variant_::Unknown(type_) => {
126 let value = map.next_value()?;
127 EnumDisplayStyle::Unknown(Unknown {
128 type_: type_.clone(),
129 value,
130 })
131 }
132 };
133 if map.next_key::<UnionTypeField_>()?.is_none() {
134 return Err(de::Error::missing_field("type"));
135 }
136 let type_variant = map.next_value::<Variant_>()?;
137 if variant != type_variant {
138 return Err(
139 de::Error::invalid_value(
140 de::Unexpected::Str(type_variant.as_str()),
141 &variant.as_str(),
142 ),
143 );
144 }
145 value
146 }
147 None => return Err(de::Error::missing_field("type")),
148 };
149 if map.next_key::<UnionField_<Variant_>>()?.is_some() {
150 return Err(de::Error::invalid_length(3, &"type and value fields"));
151 }
152 Ok(v)
153 }
154}
155#[derive(PartialEq)]
156enum Variant_ {
157 Stacked,
158 Inline,
159 Bar,
160 Line,
161 Unknown(Box<str>),
162}
163impl Variant_ {
164 fn as_str(&self) -> &'static str {
165 match *self {
166 Variant_::Stacked => "stacked",
167 Variant_::Inline => "inline",
168 Variant_::Bar => "bar",
169 Variant_::Line => "line",
170 Variant_::Unknown(_) => "unknown variant",
171 }
172 }
173}
174impl<'de> de::Deserialize<'de> for Variant_ {
175 fn deserialize<D>(d: D) -> Result<Variant_, D::Error>
176 where
177 D: de::Deserializer<'de>,
178 {
179 d.deserialize_str(VariantVisitor_)
180 }
181}
182struct VariantVisitor_;
183impl<'de> de::Visitor<'de> for VariantVisitor_ {
184 type Value = Variant_;
185 fn expecting(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
186 fmt.write_str("string")
187 }
188 fn visit_str<E>(self, value: &str) -> Result<Variant_, E>
189 where
190 E: de::Error,
191 {
192 let v = match value {
193 "stacked" => Variant_::Stacked,
194 "inline" => Variant_::Inline,
195 "bar" => Variant_::Bar,
196 "line" => Variant_::Line,
197 value => Variant_::Unknown(value.to_string().into_boxed_str()),
198 };
199 Ok(v)
200 }
201}
202#[derive(Debug, Clone, PartialEq, Eq, PartialOrd, Ord, Hash)]
204pub struct Unknown {
205 type_: Box<str>,
206 value: conjure_object::Any,
207}
208impl Unknown {
209 #[inline]
211 pub fn type_(&self) -> &str {
212 &self.type_
213 }
214}