1use super::class_requires::*;
2use super::*;
3#[allow(non_upper_case_globals, non_snake_case)]
10#[cfg_attr(feature = "json_schema", derive(schemars::JsonSchema))]
11#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
12#[derive(educe::Educe)]
13#[educe(Debug, Clone, Default, PartialEq)]
14pub struct hkRootLevelContainerNamedVariant<'a> {
15 #[cfg_attr(
22 feature = "serde",
23 serde(skip_serializing_if = "Option::is_none", default)
24 )]
25 pub __ptr: Option<Pointer>,
26 #[cfg_attr(feature = "serde", serde(borrow))]
31 #[cfg_attr(feature = "json_schema", schemars(rename = "name"))]
32 #[cfg_attr(feature = "serde", serde(rename = "name"))]
33 pub m_name: StringPtr<'a>,
34 #[cfg_attr(feature = "serde", serde(borrow))]
39 #[cfg_attr(feature = "json_schema", schemars(rename = "className"))]
40 #[cfg_attr(feature = "serde", serde(rename = "className"))]
41 pub m_className: StringPtr<'a>,
42 #[cfg_attr(feature = "json_schema", schemars(rename = "variant"))]
47 #[cfg_attr(feature = "serde", serde(rename = "variant"))]
48 pub m_variant: Pointer,
49}
50const _: () = {
51 use havok_serde as _serde;
52 impl<'a> _serde::HavokClass for hkRootLevelContainerNamedVariant<'a> {
53 #[inline]
54 fn name(&self) -> &'static str {
55 "hkRootLevelContainerNamedVariant"
56 }
57 #[inline]
58 fn signature(&self) -> _serde::__private::Signature {
59 _serde::__private::Signature::new(0xb103a2cd)
60 }
61 #[allow(clippy::let_and_return, clippy::vec_init_then_push)]
62 fn deps_indexes(&self) -> Vec<usize> {
63 let mut v = Vec::new();
64 v.push(self.m_variant.get());
65 v
66 }
67 }
68 impl<'a> _serde::Serialize for hkRootLevelContainerNamedVariant<'a> {
69 fn serialize<S>(&self, __serializer: S) -> Result<S::Ok, S::Error>
70 where
71 S: _serde::ser::Serializer,
72 {
73 let class_meta = self
74 .__ptr
75 .map(|name| (name, _serde::__private::Signature::new(0xb103a2cd)));
76 let mut serializer = __serializer
77 .serialize_struct(
78 "hkRootLevelContainerNamedVariant",
79 class_meta,
80 (12u64, 24u64),
81 )?;
82 serializer.serialize_field("name", &self.m_name)?;
83 serializer.serialize_field("className", &self.m_className)?;
84 serializer.serialize_field("variant", &self.m_variant)?;
85 serializer.end()
86 }
87 }
88};
89#[doc(hidden)]
90#[allow(non_upper_case_globals, unused_attributes, unused_qualifications)]
91const _: () = {
92 use havok_serde as _serde;
93 #[automatically_derived]
94 impl<'de> _serde::Deserialize<'de> for hkRootLevelContainerNamedVariant<'de> {
95 fn deserialize<__D>(deserializer: __D) -> core::result::Result<Self, __D::Error>
96 where
97 __D: _serde::Deserializer<'de>,
98 {
99 #[allow(non_camel_case_types)]
100 enum __Field {
101 m_name,
102 m_className,
103 m_variant,
104 __ignore,
105 }
106 struct __FieldVisitor;
107 impl<'de> _serde::de::Visitor<'de> for __FieldVisitor {
108 type Value = __Field;
109 fn expecting(
110 &self,
111 __formatter: &mut core::fmt::Formatter,
112 ) -> core::fmt::Result {
113 core::fmt::Formatter::write_str(__formatter, "field identifier")
114 }
115 #[allow(clippy::match_single_binding)]
117 #[allow(clippy::reversed_empty_ranges)]
118 #[allow(clippy::single_match)]
119 fn visit_key<__E>(
120 self,
121 __value: &str,
122 ) -> core::result::Result<Self::Value, __E>
123 where
124 __E: _serde::de::Error,
125 {
126 match __value {
127 "name" => Ok(__Field::m_name),
128 "className" => Ok(__Field::m_className),
129 "variant" => Ok(__Field::m_variant),
130 _ => Ok(__Field::__ignore),
131 }
132 }
133 }
134 impl<'de> _serde::Deserialize<'de> for __Field {
135 #[inline]
136 fn deserialize<__D>(
137 __deserializer: __D,
138 ) -> core::result::Result<Self, __D::Error>
139 where
140 __D: _serde::Deserializer<'de>,
141 {
142 _serde::Deserializer::deserialize_key(__deserializer, __FieldVisitor)
143 }
144 }
145 struct __hkRootLevelContainerNamedVariantVisitor<'de> {
146 marker: _serde::__private::PhantomData<
147 hkRootLevelContainerNamedVariant<'de>,
148 >,
149 lifetime: _serde::__private::PhantomData<&'de ()>,
150 }
151 #[allow(clippy::match_single_binding)]
152 #[allow(clippy::reversed_empty_ranges)]
153 #[allow(clippy::single_match)]
154 impl<'de> _serde::de::Visitor<'de>
155 for __hkRootLevelContainerNamedVariantVisitor<'de> {
156 type Value = hkRootLevelContainerNamedVariant<'de>;
157 fn expecting(
158 &self,
159 __formatter: &mut core::fmt::Formatter,
160 ) -> core::fmt::Result {
161 core::fmt::Formatter::write_str(
162 __formatter,
163 "struct hkRootLevelContainerNamedVariant",
164 )
165 }
166 fn visit_struct_for_bytes<__A>(
167 self,
168 mut __map: __A,
169 ) -> _serde::__private::Result<Self::Value, __A::Error>
170 where
171 __A: _serde::de::MapAccess<'de>,
172 {
173 let __ptr = __A::class_ptr(&mut __map);
174 let mut m_name: _serde::__private::Option<StringPtr<'de>> = _serde::__private::None;
175 let mut m_className: _serde::__private::Option<StringPtr<'de>> = _serde::__private::None;
176 let mut m_variant: _serde::__private::Option<Pointer> = _serde::__private::None;
177 for i in 0..3usize {
178 match i {
179 0usize => {
180 if _serde::__private::Option::is_some(&m_name) {
181 return _serde::__private::Err(
182 <__A::Error as _serde::de::Error>::duplicate_field("name"),
183 );
184 }
185 m_name = _serde::__private::Some(
186 match __A::next_value::<StringPtr<'de>>(&mut __map) {
187 _serde::__private::Ok(__val) => __val,
188 _serde::__private::Err(__err) => {
189 return _serde::__private::Err(__err);
190 }
191 },
192 );
193 }
194 1usize => {
195 if _serde::__private::Option::is_some(&m_className) {
196 return _serde::__private::Err(
197 <__A::Error as _serde::de::Error>::duplicate_field(
198 "className",
199 ),
200 );
201 }
202 m_className = _serde::__private::Some(
203 match __A::next_value::<StringPtr<'de>>(&mut __map) {
204 _serde::__private::Ok(__val) => __val,
205 _serde::__private::Err(__err) => {
206 return _serde::__private::Err(__err);
207 }
208 },
209 );
210 }
211 2usize => {
212 if _serde::__private::Option::is_some(&m_variant) {
213 return _serde::__private::Err(
214 <__A::Error as _serde::de::Error>::duplicate_field(
215 "variant",
216 ),
217 );
218 }
219 m_variant = _serde::__private::Some(
220 match __A::next_value::<Pointer>(&mut __map) {
221 _serde::__private::Ok(__val) => __val,
222 _serde::__private::Err(__err) => {
223 return _serde::__private::Err(__err);
224 }
225 },
226 );
227 }
228 _ => {}
229 }
230 }
231 let m_name = match m_name {
232 _serde::__private::Some(__field) => __field,
233 _serde::__private::None => {
234 return _serde::__private::Err(
235 <__A::Error as _serde::de::Error>::missing_field("name"),
236 );
237 }
238 };
239 let m_className = match m_className {
240 _serde::__private::Some(__field) => __field,
241 _serde::__private::None => {
242 return _serde::__private::Err(
243 <__A::Error as _serde::de::Error>::missing_field(
244 "className",
245 ),
246 );
247 }
248 };
249 let m_variant = match m_variant {
250 _serde::__private::Some(__field) => __field,
251 _serde::__private::None => {
252 return _serde::__private::Err(
253 <__A::Error as _serde::de::Error>::missing_field("variant"),
254 );
255 }
256 };
257 _serde::__private::Ok(hkRootLevelContainerNamedVariant {
258 __ptr,
259 m_name,
260 m_className,
261 m_variant,
262 })
263 }
264 #[allow(clippy::manual_unwrap_or_default)]
265 fn visit_struct<__A>(
266 self,
267 mut __map: __A,
268 ) -> _serde::__private::Result<Self::Value, __A::Error>
269 where
270 __A: _serde::de::MapAccess<'de>,
271 {
272 let mut m_name: _serde::__private::Option<StringPtr<'de>> = _serde::__private::None;
273 let mut m_className: _serde::__private::Option<StringPtr<'de>> = _serde::__private::None;
274 let mut m_variant: _serde::__private::Option<Pointer> = _serde::__private::None;
275 while let _serde::__private::Some(__key) = {
276 __A::next_key::<__Field>(&mut __map)?
277 } {
278 match __key {
279 __Field::m_name => {
280 #[cfg(
281 any(feature = "strict", feature = "ignore_duplicates")
282 )]
283 if _serde::__private::Option::is_some(&m_name) {
284 #[cfg(feature = "ignore_duplicates")]
285 {
286 __A::skip_value(&mut __map)?;
287 continue;
288 }
289 #[cfg(feature = "strict")]
290 return _serde::__private::Err(
291 <__A::Error as _serde::de::Error>::duplicate_field("name"),
292 );
293 }
294 m_name = _serde::__private::Some(
295 match __A::next_value::<StringPtr<'de>>(&mut __map) {
296 _serde::__private::Ok(__val) => __val,
297 _serde::__private::Err(__err) => {
298 return _serde::__private::Err(__err);
299 }
300 },
301 );
302 }
303 __Field::m_className => {
304 #[cfg(
305 any(feature = "strict", feature = "ignore_duplicates")
306 )]
307 if _serde::__private::Option::is_some(&m_className) {
308 #[cfg(feature = "ignore_duplicates")]
309 {
310 __A::skip_value(&mut __map)?;
311 continue;
312 }
313 #[cfg(feature = "strict")]
314 return _serde::__private::Err(
315 <__A::Error as _serde::de::Error>::duplicate_field(
316 "className",
317 ),
318 );
319 }
320 m_className = _serde::__private::Some(
321 match __A::next_value::<StringPtr<'de>>(&mut __map) {
322 _serde::__private::Ok(__val) => __val,
323 _serde::__private::Err(__err) => {
324 return _serde::__private::Err(__err);
325 }
326 },
327 );
328 }
329 __Field::m_variant => {
330 #[cfg(
331 any(feature = "strict", feature = "ignore_duplicates")
332 )]
333 if _serde::__private::Option::is_some(&m_variant) {
334 #[cfg(feature = "ignore_duplicates")]
335 {
336 __A::skip_value(&mut __map)?;
337 continue;
338 }
339 #[cfg(feature = "strict")]
340 return _serde::__private::Err(
341 <__A::Error as _serde::de::Error>::duplicate_field(
342 "variant",
343 ),
344 );
345 }
346 m_variant = _serde::__private::Some(
347 match __A::next_value::<Pointer>(&mut __map) {
348 _serde::__private::Ok(__val) => __val,
349 _serde::__private::Err(__err) => {
350 return _serde::__private::Err(__err);
351 }
352 },
353 );
354 }
355 _ => __A::skip_value(&mut __map)?,
356 }
357 }
358 let m_name = match m_name {
359 _serde::__private::Some(__field) => __field,
360 _serde::__private::None => {
361 #[cfg(feature = "strict")]
362 return _serde::__private::Err(
363 <__A::Error as _serde::de::Error>::missing_field("name"),
364 );
365 #[cfg(not(feature = "strict"))] Default::default()
366 }
367 };
368 let m_className = match m_className {
369 _serde::__private::Some(__field) => __field,
370 _serde::__private::None => {
371 #[cfg(feature = "strict")]
372 return _serde::__private::Err(
373 <__A::Error as _serde::de::Error>::missing_field(
374 "className",
375 ),
376 );
377 #[cfg(not(feature = "strict"))] Default::default()
378 }
379 };
380 let m_variant = match m_variant {
381 _serde::__private::Some(__field) => __field,
382 _serde::__private::None => {
383 #[cfg(feature = "strict")]
384 return _serde::__private::Err(
385 <__A::Error as _serde::de::Error>::missing_field("variant"),
386 );
387 #[cfg(not(feature = "strict"))] Default::default()
388 }
389 };
390 let __ptr = __A::class_ptr(&mut __map);
391 _serde::__private::Ok(hkRootLevelContainerNamedVariant {
392 __ptr,
393 m_name,
394 m_className,
395 m_variant,
396 })
397 }
398 }
399 const FIELDS: &[&str] = &["name", "className", "variant"];
400 _serde::Deserializer::deserialize_struct(
401 deserializer,
402 "hkRootLevelContainerNamedVariant",
403 FIELDS,
404 __hkRootLevelContainerNamedVariantVisitor {
405 marker: _serde::__private::PhantomData::<
406 hkRootLevelContainerNamedVariant,
407 >,
408 lifetime: _serde::__private::PhantomData,
409 },
410 )
411 }
412 }
413};