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