havok_classes/generated/
hkReferencedObject_.rs

1use super::class_requires::*;
2use super::*;
3/// # C++ Info
4/// - name: `hkReferencedObject`
5/// - version: `0`
6/// - signature: `0x3b1c1113`
7/// - size: `  8`(x86)/` 16`(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 hkReferencedObject {
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: hkBaseObject,
30    /// # C++ Info
31    /// - name: `memSizeAndFlags`(ctype: `hkUint16`)
32    /// - offset: `  4`(x86)/`  8`(x86_64)
33    /// - type_size: `  2`(x86)/`  2`(x86_64)
34    /// - flags: `SERIALIZE_IGNORED`
35    #[cfg_attr(feature = "json_schema", schemars(rename = "memSizeAndFlags"))]
36    #[cfg_attr(feature = "serde", serde(rename = "memSizeAndFlags"))]
37    pub m_memSizeAndFlags: u16,
38    /// # C++ Info
39    /// - name: `referenceCount`(ctype: `hkInt16`)
40    /// - offset: `  6`(x86)/` 10`(x86_64)
41    /// - type_size: `  2`(x86)/`  2`(x86_64)
42    /// - flags: `SERIALIZE_IGNORED`
43    #[cfg_attr(feature = "json_schema", schemars(rename = "referenceCount"))]
44    #[cfg_attr(feature = "serde", serde(rename = "referenceCount"))]
45    pub m_referenceCount: i16,
46}
47const _: () = {
48    use havok_serde as _serde;
49    impl _serde::HavokClass for hkReferencedObject {
50        #[inline]
51        fn name(&self) -> &'static str {
52            "hkReferencedObject"
53        }
54        #[inline]
55        fn signature(&self) -> _serde::__private::Signature {
56            _serde::__private::Signature::new(0x3b1c1113)
57        }
58        #[allow(clippy::let_and_return, clippy::vec_init_then_push)]
59        fn deps_indexes(&self) -> Vec<usize> {
60            let mut v = Vec::new();
61            v
62        }
63    }
64    impl _serde::Serialize for hkReferencedObject {
65        fn serialize<S>(&self, __serializer: S) -> Result<S::Ok, S::Error>
66        where
67            S: _serde::ser::Serializer,
68        {
69            let class_meta = self
70                .__ptr
71                .map(|name| (name, _serde::__private::Signature::new(0x3b1c1113)));
72            let mut serializer = __serializer
73                .serialize_struct("hkReferencedObject", class_meta, (8u64, 16u64))?;
74            serializer.pad_field([0u8; 4usize].as_slice(), [0u8; 8usize].as_slice())?;
75            serializer.skip_field("memSizeAndFlags", &self.m_memSizeAndFlags)?;
76            serializer.skip_field("referenceCount", &self.m_referenceCount)?;
77            serializer.pad_field([0u8; 0usize].as_slice(), [0u8; 4usize].as_slice())?;
78            serializer.end()
79        }
80    }
81};
82#[doc(hidden)]
83#[allow(non_upper_case_globals, unused_attributes, unused_qualifications)]
84const _: () = {
85    use havok_serde as _serde;
86    #[automatically_derived]
87    impl<'de> _serde::Deserialize<'de> for hkReferencedObject {
88        fn deserialize<__D>(deserializer: __D) -> core::result::Result<Self, __D::Error>
89        where
90            __D: _serde::Deserializer<'de>,
91        {
92            #[allow(non_camel_case_types)]
93            enum __Field {
94                __ignore,
95            }
96            struct __FieldVisitor;
97            impl<'de> _serde::de::Visitor<'de> for __FieldVisitor {
98                type Value = __Field;
99                fn expecting(
100                    &self,
101                    __formatter: &mut core::fmt::Formatter,
102                ) -> core::fmt::Result {
103                    core::fmt::Formatter::write_str(__formatter, "field identifier")
104                }
105                /// Intended for use in XML.
106                #[allow(clippy::match_single_binding)]
107                #[allow(clippy::reversed_empty_ranges)]
108                #[allow(clippy::single_match)]
109                fn visit_key<__E>(
110                    self,
111                    __value: &str,
112                ) -> core::result::Result<Self::Value, __E>
113                where
114                    __E: _serde::de::Error,
115                {
116                    match __value {
117                        _ => Ok(__Field::__ignore),
118                    }
119                }
120            }
121            impl<'de> _serde::Deserialize<'de> for __Field {
122                #[inline]
123                fn deserialize<__D>(
124                    __deserializer: __D,
125                ) -> core::result::Result<Self, __D::Error>
126                where
127                    __D: _serde::Deserializer<'de>,
128                {
129                    _serde::Deserializer::deserialize_key(__deserializer, __FieldVisitor)
130                }
131            }
132            struct __hkReferencedObjectVisitor<'de> {
133                marker: _serde::__private::PhantomData<hkReferencedObject>,
134                lifetime: _serde::__private::PhantomData<&'de ()>,
135            }
136            #[allow(clippy::match_single_binding)]
137            #[allow(clippy::reversed_empty_ranges)]
138            #[allow(clippy::single_match)]
139            impl<'de> _serde::de::Visitor<'de> for __hkReferencedObjectVisitor<'de> {
140                type Value = hkReferencedObject;
141                fn expecting(
142                    &self,
143                    __formatter: &mut core::fmt::Formatter,
144                ) -> core::fmt::Result {
145                    core::fmt::Formatter::write_str(
146                        __formatter,
147                        "struct hkReferencedObject",
148                    )
149                }
150                fn visit_struct_for_bytes<__A>(
151                    self,
152                    mut __map: __A,
153                ) -> _serde::__private::Result<Self::Value, __A::Error>
154                where
155                    __A: _serde::de::MapAccess<'de>,
156                {
157                    let __ptr = __A::class_ptr(&mut __map);
158                    let parent = __A::parent_value(&mut __map)?;
159                    let mut m_memSizeAndFlags: _serde::__private::Option<u16> = _serde::__private::None;
160                    let mut m_referenceCount: _serde::__private::Option<i16> = _serde::__private::None;
161                    for i in 0..2usize {
162                        match i {
163                            0usize => {
164                                if _serde::__private::Option::is_some(&m_memSizeAndFlags) {
165                                    return _serde::__private::Err(
166                                        <__A::Error as _serde::de::Error>::duplicate_field(
167                                            "memSizeAndFlags",
168                                        ),
169                                    );
170                                }
171                                m_memSizeAndFlags = _serde::__private::Some(
172                                    match __A::next_value::<u16>(&mut __map) {
173                                        _serde::__private::Ok(__val) => __val,
174                                        _serde::__private::Err(__err) => {
175                                            return _serde::__private::Err(__err);
176                                        }
177                                    },
178                                );
179                            }
180                            1usize => {
181                                if _serde::__private::Option::is_some(&m_referenceCount) {
182                                    return _serde::__private::Err(
183                                        <__A::Error as _serde::de::Error>::duplicate_field(
184                                            "referenceCount",
185                                        ),
186                                    );
187                                }
188                                m_referenceCount = _serde::__private::Some(
189                                    match __A::next_value::<i16>(&mut __map) {
190                                        _serde::__private::Ok(__val) => __val,
191                                        _serde::__private::Err(__err) => {
192                                            return _serde::__private::Err(__err);
193                                        }
194                                    },
195                                );
196                            }
197                            _ => {}
198                        }
199                    }
200                    __A::pad(&mut __map, 0usize, 4usize)?;
201                    let m_memSizeAndFlags = match m_memSizeAndFlags {
202                        _serde::__private::Some(__field) => __field,
203                        _serde::__private::None => {
204                            return _serde::__private::Err(
205                                <__A::Error as _serde::de::Error>::missing_field(
206                                    "memSizeAndFlags",
207                                ),
208                            );
209                        }
210                    };
211                    let m_referenceCount = match m_referenceCount {
212                        _serde::__private::Some(__field) => __field,
213                        _serde::__private::None => {
214                            return _serde::__private::Err(
215                                <__A::Error as _serde::de::Error>::missing_field(
216                                    "referenceCount",
217                                ),
218                            );
219                        }
220                    };
221                    _serde::__private::Ok(hkReferencedObject {
222                        __ptr,
223                        parent,
224                        m_memSizeAndFlags,
225                        m_referenceCount,
226                    })
227                }
228                #[allow(clippy::manual_unwrap_or_default)]
229                fn visit_struct<__A>(
230                    self,
231                    mut __map: __A,
232                ) -> _serde::__private::Result<Self::Value, __A::Error>
233                where
234                    __A: _serde::de::MapAccess<'de>,
235                {
236                    while let _serde::__private::Some(__key) = {
237                        __A::next_key::<__Field>(&mut __map)?
238                    } {
239                        match __key {
240                            _ => __A::skip_value(&mut __map)?,
241                        }
242                    }
243                    let __ptr = None;
244                    let parent = hkBaseObject { __ptr };
245                    let __ptr = __A::class_ptr(&mut __map);
246                    _serde::__private::Ok(hkReferencedObject {
247                        __ptr,
248                        parent,
249                        ..Default::default()
250                    })
251                }
252            }
253            const FIELDS: &[&str] = &["memSizeAndFlags", "referenceCount"];
254            _serde::Deserializer::deserialize_struct(
255                deserializer,
256                "hkReferencedObject",
257                FIELDS,
258                __hkReferencedObjectVisitor {
259                    marker: _serde::__private::PhantomData::<hkReferencedObject>,
260                    lifetime: _serde::__private::PhantomData,
261                },
262            )
263        }
264    }
265};