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 hkpRackAndPinionConstraintData {
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: hkpConstraintData,
30 #[cfg_attr(feature = "json_schema", schemars(rename = "atoms"))]
36 #[cfg_attr(feature = "serde", serde(rename = "atoms"))]
37 pub m_atoms: hkpRackAndPinionConstraintDataAtoms,
38}
39const _: () = {
40 use havok_serde as _serde;
41 impl _serde::HavokClass for hkpRackAndPinionConstraintData {
42 #[inline]
43 fn name(&self) -> &'static str {
44 "hkpRackAndPinionConstraintData"
45 }
46 #[inline]
47 fn signature(&self) -> _serde::__private::Signature {
48 _serde::__private::Signature::new(0xd180ebe0)
49 }
50 #[allow(clippy::let_and_return, clippy::vec_init_then_push)]
51 fn deps_indexes(&self) -> Vec<usize> {
52 let mut v = Vec::new();
53 v.extend(self.m_atoms.deps_indexes());
54 v
55 }
56 }
57 impl _serde::Serialize for hkpRackAndPinionConstraintData {
58 fn serialize<S>(&self, __serializer: S) -> Result<S::Ok, S::Error>
59 where
60 S: _serde::ser::Serializer,
61 {
62 let class_meta = self
63 .__ptr
64 .map(|name| (name, _serde::__private::Signature::new(0xd180ebe0)));
65 let mut serializer = __serializer
66 .serialize_struct(
67 "hkpRackAndPinionConstraintData",
68 class_meta,
69 (176u64, 192u64),
70 )?;
71 serializer.pad_field([0u8; 4usize].as_slice(), [0u8; 8usize].as_slice())?;
72 serializer
73 .skip_field("memSizeAndFlags", &self.parent.parent.m_memSizeAndFlags)?;
74 serializer
75 .skip_field("referenceCount", &self.parent.parent.m_referenceCount)?;
76 serializer.pad_field([0u8; 0usize].as_slice(), [0u8; 4usize].as_slice())?;
77 serializer.serialize_field("userData", &self.parent.m_userData)?;
78 serializer.pad_field([0u8; 4usize].as_slice(), [0u8; 8usize].as_slice())?;
79 serializer.serialize_field("atoms", &self.m_atoms)?;
80 serializer.end()
81 }
82 }
83};
84#[doc(hidden)]
85#[allow(non_upper_case_globals, unused_attributes, unused_qualifications)]
86const _: () = {
87 use havok_serde as _serde;
88 #[automatically_derived]
89 impl<'de> _serde::Deserialize<'de> for hkpRackAndPinionConstraintData {
90 fn deserialize<__D>(deserializer: __D) -> core::result::Result<Self, __D::Error>
91 where
92 __D: _serde::Deserializer<'de>,
93 {
94 #[allow(non_camel_case_types)]
95 enum __Field {
96 m_userData,
97 m_atoms,
98 __ignore,
99 }
100 struct __FieldVisitor;
101 impl<'de> _serde::de::Visitor<'de> for __FieldVisitor {
102 type Value = __Field;
103 fn expecting(
104 &self,
105 __formatter: &mut core::fmt::Formatter,
106 ) -> core::fmt::Result {
107 core::fmt::Formatter::write_str(__formatter, "field identifier")
108 }
109 #[allow(clippy::match_single_binding)]
111 #[allow(clippy::reversed_empty_ranges)]
112 #[allow(clippy::single_match)]
113 fn visit_key<__E>(
114 self,
115 __value: &str,
116 ) -> core::result::Result<Self::Value, __E>
117 where
118 __E: _serde::de::Error,
119 {
120 match __value {
121 "userData" => Ok(__Field::m_userData),
122 "atoms" => Ok(__Field::m_atoms),
123 _ => Ok(__Field::__ignore),
124 }
125 }
126 }
127 impl<'de> _serde::Deserialize<'de> for __Field {
128 #[inline]
129 fn deserialize<__D>(
130 __deserializer: __D,
131 ) -> core::result::Result<Self, __D::Error>
132 where
133 __D: _serde::Deserializer<'de>,
134 {
135 _serde::Deserializer::deserialize_key(__deserializer, __FieldVisitor)
136 }
137 }
138 struct __hkpRackAndPinionConstraintDataVisitor<'de> {
139 marker: _serde::__private::PhantomData<hkpRackAndPinionConstraintData>,
140 lifetime: _serde::__private::PhantomData<&'de ()>,
141 }
142 #[allow(clippy::match_single_binding)]
143 #[allow(clippy::reversed_empty_ranges)]
144 #[allow(clippy::single_match)]
145 impl<'de> _serde::de::Visitor<'de>
146 for __hkpRackAndPinionConstraintDataVisitor<'de> {
147 type Value = hkpRackAndPinionConstraintData;
148 fn expecting(
149 &self,
150 __formatter: &mut core::fmt::Formatter,
151 ) -> core::fmt::Result {
152 core::fmt::Formatter::write_str(
153 __formatter,
154 "struct hkpRackAndPinionConstraintData",
155 )
156 }
157 fn visit_struct_for_bytes<__A>(
158 self,
159 mut __map: __A,
160 ) -> _serde::__private::Result<Self::Value, __A::Error>
161 where
162 __A: _serde::de::MapAccess<'de>,
163 {
164 let __ptr = __A::class_ptr(&mut __map);
165 let parent = __A::parent_value(&mut __map)?;
166 let mut m_atoms: _serde::__private::Option<
167 hkpRackAndPinionConstraintDataAtoms,
168 > = _serde::__private::None;
169 for i in 0..1usize {
170 match i {
171 0usize => {
172 if _serde::__private::Option::is_some(&m_atoms) {
173 return _serde::__private::Err(
174 <__A::Error as _serde::de::Error>::duplicate_field("atoms"),
175 );
176 }
177 __A::pad(&mut __map, 4usize, 8usize)?;
178 m_atoms = _serde::__private::Some(
179 match __A::next_value::<
180 hkpRackAndPinionConstraintDataAtoms,
181 >(&mut __map) {
182 _serde::__private::Ok(__val) => __val,
183 _serde::__private::Err(__err) => {
184 return _serde::__private::Err(__err);
185 }
186 },
187 );
188 }
189 _ => {}
190 }
191 }
192 let m_atoms = match m_atoms {
193 _serde::__private::Some(__field) => __field,
194 _serde::__private::None => {
195 return _serde::__private::Err(
196 <__A::Error as _serde::de::Error>::missing_field("atoms"),
197 );
198 }
199 };
200 _serde::__private::Ok(hkpRackAndPinionConstraintData {
201 __ptr,
202 parent,
203 m_atoms,
204 })
205 }
206 #[allow(clippy::manual_unwrap_or_default)]
207 fn visit_struct<__A>(
208 self,
209 mut __map: __A,
210 ) -> _serde::__private::Result<Self::Value, __A::Error>
211 where
212 __A: _serde::de::MapAccess<'de>,
213 {
214 let mut m_userData: _serde::__private::Option<Ulong> = _serde::__private::None;
215 let mut m_atoms: _serde::__private::Option<
216 hkpRackAndPinionConstraintDataAtoms,
217 > = _serde::__private::None;
218 while let _serde::__private::Some(__key) = {
219 __A::next_key::<__Field>(&mut __map)?
220 } {
221 match __key {
222 __Field::m_userData => {
223 #[cfg(
224 any(feature = "strict", feature = "ignore_duplicates")
225 )]
226 if _serde::__private::Option::is_some(&m_userData) {
227 #[cfg(feature = "ignore_duplicates")]
228 {
229 __A::skip_value(&mut __map)?;
230 continue;
231 }
232 #[cfg(feature = "strict")]
233 return _serde::__private::Err(
234 <__A::Error as _serde::de::Error>::duplicate_field(
235 "userData",
236 ),
237 );
238 }
239 m_userData = _serde::__private::Some(
240 match __A::next_value::<Ulong>(&mut __map) {
241 _serde::__private::Ok(__val) => __val,
242 _serde::__private::Err(__err) => {
243 return _serde::__private::Err(__err);
244 }
245 },
246 );
247 }
248 __Field::m_atoms => {
249 #[cfg(
250 any(feature = "strict", feature = "ignore_duplicates")
251 )]
252 if _serde::__private::Option::is_some(&m_atoms) {
253 #[cfg(feature = "ignore_duplicates")]
254 {
255 __A::skip_value(&mut __map)?;
256 continue;
257 }
258 #[cfg(feature = "strict")]
259 return _serde::__private::Err(
260 <__A::Error as _serde::de::Error>::duplicate_field("atoms"),
261 );
262 }
263 m_atoms = _serde::__private::Some(
264 match __A::next_value::<
265 hkpRackAndPinionConstraintDataAtoms,
266 >(&mut __map) {
267 _serde::__private::Ok(__val) => __val,
268 _serde::__private::Err(__err) => {
269 return _serde::__private::Err(__err);
270 }
271 },
272 );
273 }
274 _ => __A::skip_value(&mut __map)?,
275 }
276 }
277 let m_userData = match m_userData {
278 _serde::__private::Some(__field) => __field,
279 _serde::__private::None => {
280 #[cfg(feature = "strict")]
281 return _serde::__private::Err(
282 <__A::Error as _serde::de::Error>::missing_field("userData"),
283 );
284 #[cfg(not(feature = "strict"))] Default::default()
285 }
286 };
287 let m_atoms = match m_atoms {
288 _serde::__private::Some(__field) => __field,
289 _serde::__private::None => {
290 #[cfg(feature = "strict")]
291 return _serde::__private::Err(
292 <__A::Error as _serde::de::Error>::missing_field("atoms"),
293 );
294 #[cfg(not(feature = "strict"))] Default::default()
295 }
296 };
297 let __ptr = None;
298 let parent = hkBaseObject { __ptr };
299 let parent = hkReferencedObject {
300 __ptr,
301 parent,
302 ..Default::default()
303 };
304 let parent = hkpConstraintData {
305 __ptr,
306 parent,
307 m_userData,
308 };
309 let __ptr = __A::class_ptr(&mut __map);
310 _serde::__private::Ok(hkpRackAndPinionConstraintData {
311 __ptr,
312 parent,
313 m_atoms,
314 })
315 }
316 }
317 const FIELDS: &[&str] = &["atoms"];
318 _serde::Deserializer::deserialize_struct(
319 deserializer,
320 "hkpRackAndPinionConstraintData",
321 FIELDS,
322 __hkpRackAndPinionConstraintDataVisitor {
323 marker: _serde::__private::PhantomData::<
324 hkpRackAndPinionConstraintData,
325 >,
326 lifetime: _serde::__private::PhantomData,
327 },
328 )
329 }
330 }
331};
332#[allow(non_upper_case_globals, non_snake_case)]
335#[cfg_attr(feature = "json_schema", derive(schemars::JsonSchema))]
336#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
337#[derive(
338 Debug,
339 Clone,
340 Default,
341 PartialEq,
342 Eq,
343 PartialOrd,
344 Ord,
345 num_derive::ToPrimitive,
346 num_derive::FromPrimitive,
347)]
348pub enum Type {
349 #[default]
350 TYPE_RACK_AND_PINION = 0isize,
351 TYPE_SCREW = 1isize,
352}
353const _: () = {
354 use havok_serde as __serde;
355 impl __serde::Serialize for Type {
356 fn serialize<S>(&self, __serializer: S) -> Result<S::Ok, S::Error>
357 where
358 S: __serde::ser::Serializer,
359 {
360 let mut __serializer = __serializer.serialize_enum_flags()?;
361 match self {
362 Self::TYPE_RACK_AND_PINION => {
363 __serializer.serialize_field("TYPE_RACK_AND_PINION", &0u64)
364 }
365 Self::TYPE_SCREW => __serializer.serialize_field("TYPE_SCREW", &1u64),
366 }?;
367 use num_traits::ToPrimitive as _;
368 let num = self.to_u8().ok_or(S::Error::custom("Failed enum Type to_u8"))?;
369 __serializer.serialize_bits(&num)?;
370 __serializer.end()
371 }
372 }
373};
374#[doc(hidden)]
375#[allow(non_upper_case_globals, unused_attributes, unused_qualifications)]
376const _: () = {
377 #[allow(unused_extern_crates, clippy::useless_attribute)]
378 extern crate havok_serde as _serde;
379 #[automatically_derived]
380 impl<'de> _serde::Deserialize<'de> for Type {
381 fn deserialize<__D>(
382 __deserializer: __D,
383 ) -> _serde::__private::Result<Self, __D::Error>
384 where
385 __D: _serde::Deserializer<'de>,
386 {
387 #[allow(non_camel_case_types)]
388 #[doc(hidden)]
389 enum __Field {
390 __field0,
391 __field1,
392 }
393 #[doc(hidden)]
394 struct __FieldVisitor;
395 impl<'de> _serde::de::Visitor<'de> for __FieldVisitor {
396 type Value = __Field;
397 fn expecting(
398 &self,
399 __formatter: &mut _serde::__private::Formatter,
400 ) -> _serde::__private::fmt::Result {
401 _serde::__private::Formatter::write_str(
402 __formatter,
403 "variant identifier",
404 )
405 }
406 fn visit_uint8<__E>(
407 self,
408 __value: u8,
409 ) -> _serde::__private::Result<Self::Value, __E>
410 where
411 __E: _serde::de::Error,
412 {
413 match __value {
414 0u8 => _serde::__private::Ok(__Field::__field0),
415 1u8 => _serde::__private::Ok(__Field::__field1),
416 _ => {
417 _serde::__private::Err(
418 _serde::de::Error::invalid_value(
419 _serde::de::Unexpected::Uint8(__value),
420 &"value(u8) of variant is one of 0, 1",
421 ),
422 )
423 }
424 }
425 }
426 fn visit_stringptr<__E>(
427 self,
428 __value: StringPtr<'de>,
429 ) -> _serde::__private::Result<Self::Value, __E>
430 where
431 __E: _serde::de::Error,
432 {
433 if let Some(__value) = __value.into_inner() {
434 match __value.as_ref() {
435 v if v == "0"
436 || v.eq_ignore_ascii_case("TYPE_RACK_AND_PINION") => {
437 _serde::__private::Ok(__Field::__field0)
438 }
439 v if v == "1" || v.eq_ignore_ascii_case("TYPE_SCREW") => {
440 _serde::__private::Ok(__Field::__field1)
441 }
442 _ => {
443 _serde::__private::Err(
444 _serde::de::Error::unknown_variant(&__value, VARIANTS),
445 )
446 }
447 }
448 } else {
449 _serde::__private::Err(
450 _serde::de::Error::unknown_variant("None", VARIANTS),
451 )
452 }
453 }
454 }
455 impl<'de> _serde::Deserialize<'de> for __Field {
456 #[inline]
457 fn deserialize<__D>(
458 __deserializer: __D,
459 ) -> _serde::__private::Result<Self, __D::Error>
460 where
461 __D: _serde::Deserializer<'de>,
462 {
463 _serde::Deserializer::deserialize_identifier(
464 __deserializer,
465 _serde::de::ReadEnumSize::Uint8,
466 __FieldVisitor,
467 )
468 }
469 }
470 #[doc(hidden)]
471 struct __Visitor<'de> {
472 marker: _serde::__private::PhantomData<Type>,
473 lifetime: _serde::__private::PhantomData<&'de ()>,
474 }
475 impl<'de> _serde::de::Visitor<'de> for __Visitor<'de> {
476 type Value = Type;
477 fn expecting(
478 &self,
479 __formatter: &mut _serde::__private::Formatter,
480 ) -> _serde::__private::fmt::Result {
481 _serde::__private::Formatter::write_str(__formatter, "enum Type")
482 }
483 fn visit_enum<__A>(
484 self,
485 __data: __A,
486 ) -> _serde::__private::Result<Self::Value, __A::Error>
487 where
488 __A: _serde::de::EnumAccess<'de>,
489 {
490 match _serde::de::EnumAccess::variant(__data)? {
491 (__Field::__field0, __variant) => {
492 _serde::de::VariantAccess::unit_variant(__variant)?;
493 _serde::__private::Ok(Type::TYPE_RACK_AND_PINION)
494 }
495 (__Field::__field1, __variant) => {
496 _serde::de::VariantAccess::unit_variant(__variant)?;
497 _serde::__private::Ok(Type::TYPE_SCREW)
498 }
499 }
500 }
501 }
502 #[doc(hidden)]
503 const VARIANTS: &'static [&'static str] = &[
504 "TYPE_RACK_AND_PINION",
505 "TYPE_SCREW",
506 ];
507 _serde::Deserializer::deserialize_enum(
508 __deserializer,
509 "Type",
510 VARIANTS,
511 __Visitor {
512 marker: _serde::__private::PhantomData::<Type>,
513 lifetime: _serde::__private::PhantomData,
514 },
515 )
516 }
517 }
518};