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