havok_classes/generated/
hkpWorldObject_.rs

1use super::class_requires::*;
2use super::*;
3/// # C++ Info
4/// - name: `hkpWorldObject`
5/// - version: `0`
6/// - signature: `0x49fb6f2e`
7/// - size: `140`(x86)/`208`(x86_64)
8/// -  vtable: `true`
9#[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    /// # Unique index for this class
16    /// - Represents a pointer on XML (`<hkobject name="#0001"></hkobject>`)
17    /// - [`Option::None`] => This class is `class in field`.(`<hkobject></hkobject>`)
18    ///
19    /// # Note
20    /// Not present in the binary & Not exist actual C++ field.
21    #[cfg_attr(
22        feature = "serde",
23        serde(skip_serializing_if = "Option::is_none", default)
24    )]
25    pub __ptr: Option<Pointer>,
26    /// Alternative to C++ class inheritance.
27    #[cfg_attr(feature = "json_schema", schemars(flatten))]
28    #[cfg_attr(feature = "serde", serde(flatten))]
29    pub parent: hkReferencedObject,
30    /// # C++ Info
31    /// - name: `world`(ctype: `void*`)
32    /// - offset: `  8`(x86)/` 16`(x86_64)
33    /// - type_size: `  4`(x86)/`  8`(x86_64)
34    /// - flags: `SERIALIZE_IGNORED`
35    #[cfg_attr(feature = "json_schema", schemars(rename = "world"))]
36    #[cfg_attr(feature = "serde", serde(rename = "world"))]
37    pub m_world: Pointer,
38    /// # C++ Info
39    /// - name: `userData`(ctype: `hkUlong`)
40    /// - offset: ` 12`(x86)/` 24`(x86_64)
41    /// - type_size: `  4`(x86)/`  8`(x86_64)
42    #[cfg_attr(feature = "json_schema", schemars(rename = "userData"))]
43    #[cfg_attr(feature = "serde", serde(rename = "userData"))]
44    pub m_userData: Ulong,
45    /// # C++ Info
46    /// - name: `collidable`(ctype: `struct hkpLinkedCollidable`)
47    /// - offset: ` 16`(x86)/` 32`(x86_64)
48    /// - type_size: ` 92`(x86)/`128`(x86_64)
49    #[cfg_attr(feature = "json_schema", schemars(rename = "collidable"))]
50    #[cfg_attr(feature = "serde", serde(rename = "collidable"))]
51    pub m_collidable: hkpLinkedCollidable,
52    /// # C++ Info
53    /// - name: `multiThreadCheck`(ctype: `struct hkMultiThreadCheck`)
54    /// - offset: `108`(x86)/`160`(x86_64)
55    /// - type_size: ` 12`(x86)/` 12`(x86_64)
56    #[cfg_attr(feature = "json_schema", schemars(rename = "multiThreadCheck"))]
57    #[cfg_attr(feature = "serde", serde(rename = "multiThreadCheck"))]
58    pub m_multiThreadCheck: hkMultiThreadCheck,
59    /// # C++ Info
60    /// - name: `name`(ctype: `hkStringPtr`)
61    /// - offset: `120`(x86)/`176`(x86_64)
62    /// - type_size: `  4`(x86)/`  8`(x86_64)
63    #[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    /// # C++ Info
68    /// - name: `properties`(ctype: `hkArray<struct hkpProperty>`)
69    /// - offset: `124`(x86)/`184`(x86_64)
70    /// - type_size: ` 12`(x86)/` 16`(x86_64)
71    #[cfg_attr(feature = "json_schema", schemars(rename = "properties"))]
72    #[cfg_attr(feature = "serde", serde(rename = "properties"))]
73    pub m_properties: Vec<hkpProperty>,
74    /// # C++ Info
75    /// - name: `treeData`(ctype: `void*`)
76    /// - offset: `136`(x86)/`200`(x86_64)
77    /// - type_size: `  4`(x86)/`  8`(x86_64)
78    /// - flags: `SERIALIZE_IGNORED`
79    #[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                /// Intended for use in XML.
174                #[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};