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 hkpTwistLimitConstraintAtom {
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: hkpConstraintAtom,
30 #[cfg_attr(feature = "json_schema", schemars(rename = "isEnabled"))]
35 #[cfg_attr(feature = "serde", serde(rename = "isEnabled"))]
36 pub m_isEnabled: u8,
37 #[cfg_attr(feature = "json_schema", schemars(rename = "twistAxis"))]
42 #[cfg_attr(feature = "serde", serde(rename = "twistAxis"))]
43 pub m_twistAxis: u8,
44 #[cfg_attr(feature = "json_schema", schemars(rename = "refAxis"))]
49 #[cfg_attr(feature = "serde", serde(rename = "refAxis"))]
50 pub m_refAxis: u8,
51 #[cfg_attr(feature = "json_schema", schemars(rename = "minAngle"))]
56 #[cfg_attr(feature = "serde", serde(rename = "minAngle"))]
57 pub m_minAngle: f32,
58 #[cfg_attr(feature = "json_schema", schemars(rename = "maxAngle"))]
63 #[cfg_attr(feature = "serde", serde(rename = "maxAngle"))]
64 pub m_maxAngle: f32,
65 #[cfg_attr(feature = "json_schema", schemars(rename = "angularLimitsTauFactor"))]
70 #[cfg_attr(feature = "serde", serde(rename = "angularLimitsTauFactor"))]
71 pub m_angularLimitsTauFactor: f32,
72}
73const _: () = {
74 use havok_serde as _serde;
75 impl _serde::HavokClass for hkpTwistLimitConstraintAtom {
76 #[inline]
77 fn name(&self) -> &'static str {
78 "hkpTwistLimitConstraintAtom"
79 }
80 #[inline]
81 fn signature(&self) -> _serde::__private::Signature {
82 _serde::__private::Signature::new(0x7c9b1052)
83 }
84 #[allow(clippy::let_and_return, clippy::vec_init_then_push)]
85 fn deps_indexes(&self) -> Vec<usize> {
86 let mut v = Vec::new();
87 v
88 }
89 }
90 impl _serde::Serialize for hkpTwistLimitConstraintAtom {
91 fn serialize<S>(&self, __serializer: S) -> Result<S::Ok, S::Error>
92 where
93 S: _serde::ser::Serializer,
94 {
95 let class_meta = self
96 .__ptr
97 .map(|name| (name, _serde::__private::Signature::new(0x7c9b1052)));
98 let mut serializer = __serializer
99 .serialize_struct(
100 "hkpTwistLimitConstraintAtom",
101 class_meta,
102 (20u64, 20u64),
103 )?;
104 serializer.serialize_field("type", &self.parent.m_type)?;
105 serializer.serialize_field("isEnabled", &self.m_isEnabled)?;
106 serializer.serialize_field("twistAxis", &self.m_twistAxis)?;
107 serializer.serialize_field("refAxis", &self.m_refAxis)?;
108 serializer.pad_field([0u8; 3usize].as_slice(), [0u8; 3usize].as_slice())?;
109 serializer.serialize_field("minAngle", &self.m_minAngle)?;
110 serializer.serialize_field("maxAngle", &self.m_maxAngle)?;
111 serializer
112 .serialize_field(
113 "angularLimitsTauFactor",
114 &self.m_angularLimitsTauFactor,
115 )?;
116 serializer.end()
117 }
118 }
119};
120#[doc(hidden)]
121#[allow(non_upper_case_globals, unused_attributes, unused_qualifications)]
122const _: () = {
123 use havok_serde as _serde;
124 #[automatically_derived]
125 impl<'de> _serde::Deserialize<'de> for hkpTwistLimitConstraintAtom {
126 fn deserialize<__D>(deserializer: __D) -> core::result::Result<Self, __D::Error>
127 where
128 __D: _serde::Deserializer<'de>,
129 {
130 #[allow(non_camel_case_types)]
131 enum __Field {
132 m_type,
133 m_isEnabled,
134 m_twistAxis,
135 m_refAxis,
136 m_minAngle,
137 m_maxAngle,
138 m_angularLimitsTauFactor,
139 __ignore,
140 }
141 struct __FieldVisitor;
142 impl<'de> _serde::de::Visitor<'de> for __FieldVisitor {
143 type Value = __Field;
144 fn expecting(
145 &self,
146 __formatter: &mut core::fmt::Formatter,
147 ) -> core::fmt::Result {
148 core::fmt::Formatter::write_str(__formatter, "field identifier")
149 }
150 #[allow(clippy::match_single_binding)]
152 #[allow(clippy::reversed_empty_ranges)]
153 #[allow(clippy::single_match)]
154 fn visit_key<__E>(
155 self,
156 __value: &str,
157 ) -> core::result::Result<Self::Value, __E>
158 where
159 __E: _serde::de::Error,
160 {
161 match __value {
162 "type" => Ok(__Field::m_type),
163 "isEnabled" => Ok(__Field::m_isEnabled),
164 "twistAxis" => Ok(__Field::m_twistAxis),
165 "refAxis" => Ok(__Field::m_refAxis),
166 "minAngle" => Ok(__Field::m_minAngle),
167 "maxAngle" => Ok(__Field::m_maxAngle),
168 "angularLimitsTauFactor" => Ok(__Field::m_angularLimitsTauFactor),
169 _ => Ok(__Field::__ignore),
170 }
171 }
172 }
173 impl<'de> _serde::Deserialize<'de> for __Field {
174 #[inline]
175 fn deserialize<__D>(
176 __deserializer: __D,
177 ) -> core::result::Result<Self, __D::Error>
178 where
179 __D: _serde::Deserializer<'de>,
180 {
181 _serde::Deserializer::deserialize_key(__deserializer, __FieldVisitor)
182 }
183 }
184 struct __hkpTwistLimitConstraintAtomVisitor<'de> {
185 marker: _serde::__private::PhantomData<hkpTwistLimitConstraintAtom>,
186 lifetime: _serde::__private::PhantomData<&'de ()>,
187 }
188 #[allow(clippy::match_single_binding)]
189 #[allow(clippy::reversed_empty_ranges)]
190 #[allow(clippy::single_match)]
191 impl<'de> _serde::de::Visitor<'de>
192 for __hkpTwistLimitConstraintAtomVisitor<'de> {
193 type Value = hkpTwistLimitConstraintAtom;
194 fn expecting(
195 &self,
196 __formatter: &mut core::fmt::Formatter,
197 ) -> core::fmt::Result {
198 core::fmt::Formatter::write_str(
199 __formatter,
200 "struct hkpTwistLimitConstraintAtom",
201 )
202 }
203 fn visit_struct_for_bytes<__A>(
204 self,
205 mut __map: __A,
206 ) -> _serde::__private::Result<Self::Value, __A::Error>
207 where
208 __A: _serde::de::MapAccess<'de>,
209 {
210 let __ptr = __A::class_ptr(&mut __map);
211 let parent = __A::parent_value(&mut __map)?;
212 let mut m_isEnabled: _serde::__private::Option<u8> = _serde::__private::None;
213 let mut m_twistAxis: _serde::__private::Option<u8> = _serde::__private::None;
214 let mut m_refAxis: _serde::__private::Option<u8> = _serde::__private::None;
215 let mut m_minAngle: _serde::__private::Option<f32> = _serde::__private::None;
216 let mut m_maxAngle: _serde::__private::Option<f32> = _serde::__private::None;
217 let mut m_angularLimitsTauFactor: _serde::__private::Option<f32> = _serde::__private::None;
218 for i in 0..6usize {
219 match i {
220 0usize => {
221 if _serde::__private::Option::is_some(&m_isEnabled) {
222 return _serde::__private::Err(
223 <__A::Error as _serde::de::Error>::duplicate_field(
224 "isEnabled",
225 ),
226 );
227 }
228 m_isEnabled = _serde::__private::Some(
229 match __A::next_value::<u8>(&mut __map) {
230 _serde::__private::Ok(__val) => __val,
231 _serde::__private::Err(__err) => {
232 return _serde::__private::Err(__err);
233 }
234 },
235 );
236 }
237 1usize => {
238 if _serde::__private::Option::is_some(&m_twistAxis) {
239 return _serde::__private::Err(
240 <__A::Error as _serde::de::Error>::duplicate_field(
241 "twistAxis",
242 ),
243 );
244 }
245 m_twistAxis = _serde::__private::Some(
246 match __A::next_value::<u8>(&mut __map) {
247 _serde::__private::Ok(__val) => __val,
248 _serde::__private::Err(__err) => {
249 return _serde::__private::Err(__err);
250 }
251 },
252 );
253 }
254 2usize => {
255 if _serde::__private::Option::is_some(&m_refAxis) {
256 return _serde::__private::Err(
257 <__A::Error as _serde::de::Error>::duplicate_field(
258 "refAxis",
259 ),
260 );
261 }
262 m_refAxis = _serde::__private::Some(
263 match __A::next_value::<u8>(&mut __map) {
264 _serde::__private::Ok(__val) => __val,
265 _serde::__private::Err(__err) => {
266 return _serde::__private::Err(__err);
267 }
268 },
269 );
270 }
271 3usize => {
272 if _serde::__private::Option::is_some(&m_minAngle) {
273 return _serde::__private::Err(
274 <__A::Error as _serde::de::Error>::duplicate_field(
275 "minAngle",
276 ),
277 );
278 }
279 __A::pad(&mut __map, 3usize, 3usize)?;
280 m_minAngle = _serde::__private::Some(
281 match __A::next_value::<f32>(&mut __map) {
282 _serde::__private::Ok(__val) => __val,
283 _serde::__private::Err(__err) => {
284 return _serde::__private::Err(__err);
285 }
286 },
287 );
288 }
289 4usize => {
290 if _serde::__private::Option::is_some(&m_maxAngle) {
291 return _serde::__private::Err(
292 <__A::Error as _serde::de::Error>::duplicate_field(
293 "maxAngle",
294 ),
295 );
296 }
297 m_maxAngle = _serde::__private::Some(
298 match __A::next_value::<f32>(&mut __map) {
299 _serde::__private::Ok(__val) => __val,
300 _serde::__private::Err(__err) => {
301 return _serde::__private::Err(__err);
302 }
303 },
304 );
305 }
306 5usize => {
307 if _serde::__private::Option::is_some(
308 &m_angularLimitsTauFactor,
309 ) {
310 return _serde::__private::Err(
311 <__A::Error as _serde::de::Error>::duplicate_field(
312 "angularLimitsTauFactor",
313 ),
314 );
315 }
316 m_angularLimitsTauFactor = _serde::__private::Some(
317 match __A::next_value::<f32>(&mut __map) {
318 _serde::__private::Ok(__val) => __val,
319 _serde::__private::Err(__err) => {
320 return _serde::__private::Err(__err);
321 }
322 },
323 );
324 }
325 _ => {}
326 }
327 }
328 let m_isEnabled = match m_isEnabled {
329 _serde::__private::Some(__field) => __field,
330 _serde::__private::None => {
331 return _serde::__private::Err(
332 <__A::Error as _serde::de::Error>::missing_field(
333 "isEnabled",
334 ),
335 );
336 }
337 };
338 let m_twistAxis = match m_twistAxis {
339 _serde::__private::Some(__field) => __field,
340 _serde::__private::None => {
341 return _serde::__private::Err(
342 <__A::Error as _serde::de::Error>::missing_field(
343 "twistAxis",
344 ),
345 );
346 }
347 };
348 let m_refAxis = match m_refAxis {
349 _serde::__private::Some(__field) => __field,
350 _serde::__private::None => {
351 return _serde::__private::Err(
352 <__A::Error as _serde::de::Error>::missing_field("refAxis"),
353 );
354 }
355 };
356 let m_minAngle = match m_minAngle {
357 _serde::__private::Some(__field) => __field,
358 _serde::__private::None => {
359 return _serde::__private::Err(
360 <__A::Error as _serde::de::Error>::missing_field("minAngle"),
361 );
362 }
363 };
364 let m_maxAngle = match m_maxAngle {
365 _serde::__private::Some(__field) => __field,
366 _serde::__private::None => {
367 return _serde::__private::Err(
368 <__A::Error as _serde::de::Error>::missing_field("maxAngle"),
369 );
370 }
371 };
372 let m_angularLimitsTauFactor = match m_angularLimitsTauFactor {
373 _serde::__private::Some(__field) => __field,
374 _serde::__private::None => {
375 return _serde::__private::Err(
376 <__A::Error as _serde::de::Error>::missing_field(
377 "angularLimitsTauFactor",
378 ),
379 );
380 }
381 };
382 _serde::__private::Ok(hkpTwistLimitConstraintAtom {
383 __ptr,
384 parent,
385 m_isEnabled,
386 m_twistAxis,
387 m_refAxis,
388 m_minAngle,
389 m_maxAngle,
390 m_angularLimitsTauFactor,
391 })
392 }
393 #[allow(clippy::manual_unwrap_or_default)]
394 fn visit_struct<__A>(
395 self,
396 mut __map: __A,
397 ) -> _serde::__private::Result<Self::Value, __A::Error>
398 where
399 __A: _serde::de::MapAccess<'de>,
400 {
401 let mut m_type: _serde::__private::Option<AtomType> = _serde::__private::None;
402 let mut m_isEnabled: _serde::__private::Option<u8> = _serde::__private::None;
403 let mut m_twistAxis: _serde::__private::Option<u8> = _serde::__private::None;
404 let mut m_refAxis: _serde::__private::Option<u8> = _serde::__private::None;
405 let mut m_minAngle: _serde::__private::Option<f32> = _serde::__private::None;
406 let mut m_maxAngle: _serde::__private::Option<f32> = _serde::__private::None;
407 let mut m_angularLimitsTauFactor: _serde::__private::Option<f32> = _serde::__private::None;
408 while let _serde::__private::Some(__key) = {
409 __A::next_key::<__Field>(&mut __map)?
410 } {
411 match __key {
412 __Field::m_type => {
413 #[cfg(
414 any(feature = "strict", feature = "ignore_duplicates")
415 )]
416 if _serde::__private::Option::is_some(&m_type) {
417 #[cfg(feature = "ignore_duplicates")]
418 {
419 __A::skip_value(&mut __map)?;
420 continue;
421 }
422 #[cfg(feature = "strict")]
423 return _serde::__private::Err(
424 <__A::Error as _serde::de::Error>::duplicate_field("type"),
425 );
426 }
427 m_type = _serde::__private::Some(
428 match __A::next_value::<AtomType>(&mut __map) {
429 _serde::__private::Ok(__val) => __val,
430 _serde::__private::Err(__err) => {
431 return _serde::__private::Err(__err);
432 }
433 },
434 );
435 }
436 __Field::m_isEnabled => {
437 #[cfg(
438 any(feature = "strict", feature = "ignore_duplicates")
439 )]
440 if _serde::__private::Option::is_some(&m_isEnabled) {
441 #[cfg(feature = "ignore_duplicates")]
442 {
443 __A::skip_value(&mut __map)?;
444 continue;
445 }
446 #[cfg(feature = "strict")]
447 return _serde::__private::Err(
448 <__A::Error as _serde::de::Error>::duplicate_field(
449 "isEnabled",
450 ),
451 );
452 }
453 m_isEnabled = _serde::__private::Some(
454 match __A::next_value::<u8>(&mut __map) {
455 _serde::__private::Ok(__val) => __val,
456 _serde::__private::Err(__err) => {
457 return _serde::__private::Err(__err);
458 }
459 },
460 );
461 }
462 __Field::m_twistAxis => {
463 #[cfg(
464 any(feature = "strict", feature = "ignore_duplicates")
465 )]
466 if _serde::__private::Option::is_some(&m_twistAxis) {
467 #[cfg(feature = "ignore_duplicates")]
468 {
469 __A::skip_value(&mut __map)?;
470 continue;
471 }
472 #[cfg(feature = "strict")]
473 return _serde::__private::Err(
474 <__A::Error as _serde::de::Error>::duplicate_field(
475 "twistAxis",
476 ),
477 );
478 }
479 m_twistAxis = _serde::__private::Some(
480 match __A::next_value::<u8>(&mut __map) {
481 _serde::__private::Ok(__val) => __val,
482 _serde::__private::Err(__err) => {
483 return _serde::__private::Err(__err);
484 }
485 },
486 );
487 }
488 __Field::m_refAxis => {
489 #[cfg(
490 any(feature = "strict", feature = "ignore_duplicates")
491 )]
492 if _serde::__private::Option::is_some(&m_refAxis) {
493 #[cfg(feature = "ignore_duplicates")]
494 {
495 __A::skip_value(&mut __map)?;
496 continue;
497 }
498 #[cfg(feature = "strict")]
499 return _serde::__private::Err(
500 <__A::Error as _serde::de::Error>::duplicate_field(
501 "refAxis",
502 ),
503 );
504 }
505 m_refAxis = _serde::__private::Some(
506 match __A::next_value::<u8>(&mut __map) {
507 _serde::__private::Ok(__val) => __val,
508 _serde::__private::Err(__err) => {
509 return _serde::__private::Err(__err);
510 }
511 },
512 );
513 }
514 __Field::m_minAngle => {
515 #[cfg(
516 any(feature = "strict", feature = "ignore_duplicates")
517 )]
518 if _serde::__private::Option::is_some(&m_minAngle) {
519 #[cfg(feature = "ignore_duplicates")]
520 {
521 __A::skip_value(&mut __map)?;
522 continue;
523 }
524 #[cfg(feature = "strict")]
525 return _serde::__private::Err(
526 <__A::Error as _serde::de::Error>::duplicate_field(
527 "minAngle",
528 ),
529 );
530 }
531 m_minAngle = _serde::__private::Some(
532 match __A::next_value::<f32>(&mut __map) {
533 _serde::__private::Ok(__val) => __val,
534 _serde::__private::Err(__err) => {
535 return _serde::__private::Err(__err);
536 }
537 },
538 );
539 }
540 __Field::m_maxAngle => {
541 #[cfg(
542 any(feature = "strict", feature = "ignore_duplicates")
543 )]
544 if _serde::__private::Option::is_some(&m_maxAngle) {
545 #[cfg(feature = "ignore_duplicates")]
546 {
547 __A::skip_value(&mut __map)?;
548 continue;
549 }
550 #[cfg(feature = "strict")]
551 return _serde::__private::Err(
552 <__A::Error as _serde::de::Error>::duplicate_field(
553 "maxAngle",
554 ),
555 );
556 }
557 m_maxAngle = _serde::__private::Some(
558 match __A::next_value::<f32>(&mut __map) {
559 _serde::__private::Ok(__val) => __val,
560 _serde::__private::Err(__err) => {
561 return _serde::__private::Err(__err);
562 }
563 },
564 );
565 }
566 __Field::m_angularLimitsTauFactor => {
567 #[cfg(
568 any(feature = "strict", feature = "ignore_duplicates")
569 )]
570 if _serde::__private::Option::is_some(
571 &m_angularLimitsTauFactor,
572 ) {
573 #[cfg(feature = "ignore_duplicates")]
574 {
575 __A::skip_value(&mut __map)?;
576 continue;
577 }
578 #[cfg(feature = "strict")]
579 return _serde::__private::Err(
580 <__A::Error as _serde::de::Error>::duplicate_field(
581 "angularLimitsTauFactor",
582 ),
583 );
584 }
585 m_angularLimitsTauFactor = _serde::__private::Some(
586 match __A::next_value::<f32>(&mut __map) {
587 _serde::__private::Ok(__val) => __val,
588 _serde::__private::Err(__err) => {
589 return _serde::__private::Err(__err);
590 }
591 },
592 );
593 }
594 _ => __A::skip_value(&mut __map)?,
595 }
596 }
597 let m_type = match m_type {
598 _serde::__private::Some(__field) => __field,
599 _serde::__private::None => {
600 #[cfg(feature = "strict")]
601 return _serde::__private::Err(
602 <__A::Error as _serde::de::Error>::missing_field("type"),
603 );
604 #[cfg(not(feature = "strict"))] Default::default()
605 }
606 };
607 let m_isEnabled = match m_isEnabled {
608 _serde::__private::Some(__field) => __field,
609 _serde::__private::None => {
610 #[cfg(feature = "strict")]
611 return _serde::__private::Err(
612 <__A::Error as _serde::de::Error>::missing_field(
613 "isEnabled",
614 ),
615 );
616 #[cfg(not(feature = "strict"))] Default::default()
617 }
618 };
619 let m_twistAxis = match m_twistAxis {
620 _serde::__private::Some(__field) => __field,
621 _serde::__private::None => {
622 #[cfg(feature = "strict")]
623 return _serde::__private::Err(
624 <__A::Error as _serde::de::Error>::missing_field(
625 "twistAxis",
626 ),
627 );
628 #[cfg(not(feature = "strict"))] Default::default()
629 }
630 };
631 let m_refAxis = match m_refAxis {
632 _serde::__private::Some(__field) => __field,
633 _serde::__private::None => {
634 #[cfg(feature = "strict")]
635 return _serde::__private::Err(
636 <__A::Error as _serde::de::Error>::missing_field("refAxis"),
637 );
638 #[cfg(not(feature = "strict"))] Default::default()
639 }
640 };
641 let m_minAngle = match m_minAngle {
642 _serde::__private::Some(__field) => __field,
643 _serde::__private::None => {
644 #[cfg(feature = "strict")]
645 return _serde::__private::Err(
646 <__A::Error as _serde::de::Error>::missing_field("minAngle"),
647 );
648 #[cfg(not(feature = "strict"))] Default::default()
649 }
650 };
651 let m_maxAngle = match m_maxAngle {
652 _serde::__private::Some(__field) => __field,
653 _serde::__private::None => {
654 #[cfg(feature = "strict")]
655 return _serde::__private::Err(
656 <__A::Error as _serde::de::Error>::missing_field("maxAngle"),
657 );
658 #[cfg(not(feature = "strict"))] Default::default()
659 }
660 };
661 let m_angularLimitsTauFactor = match m_angularLimitsTauFactor {
662 _serde::__private::Some(__field) => __field,
663 _serde::__private::None => {
664 #[cfg(feature = "strict")]
665 return _serde::__private::Err(
666 <__A::Error as _serde::de::Error>::missing_field(
667 "angularLimitsTauFactor",
668 ),
669 );
670 #[cfg(not(feature = "strict"))] Default::default()
671 }
672 };
673 let __ptr = None;
674 let parent = hkpConstraintAtom { __ptr, m_type };
675 let __ptr = __A::class_ptr(&mut __map);
676 _serde::__private::Ok(hkpTwistLimitConstraintAtom {
677 __ptr,
678 parent,
679 m_isEnabled,
680 m_twistAxis,
681 m_refAxis,
682 m_minAngle,
683 m_maxAngle,
684 m_angularLimitsTauFactor,
685 })
686 }
687 }
688 const FIELDS: &[&str] = &[
689 "isEnabled",
690 "twistAxis",
691 "refAxis",
692 "minAngle",
693 "maxAngle",
694 "angularLimitsTauFactor",
695 ];
696 _serde::Deserializer::deserialize_struct(
697 deserializer,
698 "hkpTwistLimitConstraintAtom",
699 FIELDS,
700 __hkpTwistLimitConstraintAtomVisitor {
701 marker: _serde::__private::PhantomData::<
702 hkpTwistLimitConstraintAtom,
703 >,
704 lifetime: _serde::__private::PhantomData,
705 },
706 )
707 }
708 }
709};