havok_classes/generated/
hkpRotationalConstraintDataAtoms_.rs

1use super::class_requires::*;
2use super::*;
3/// # C++ Info
4/// - name: `hkpRotationalConstraintDataAtoms`
5/// - version: `0`
6/// - signature: `0xa0c64586`
7/// - size: `128`(x86)/`128`(x86_64)
8/// -  vtable: `false`
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 hkpRotationalConstraintDataAtoms {
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    /// # C++ Info
27    /// - name: `rotations`(ctype: `struct hkpSetLocalRotationsConstraintAtom`)
28    /// - offset: `  0`(x86)/`  0`(x86_64)
29    /// - type_size: `112`(x86)/`112`(x86_64)
30    #[cfg_attr(feature = "json_schema", schemars(rename = "rotations"))]
31    #[cfg_attr(feature = "serde", serde(rename = "rotations"))]
32    pub m_rotations: hkpSetLocalRotationsConstraintAtom,
33    /// # C++ Info
34    /// - name: `ang`(ctype: `struct hkpAngConstraintAtom`)
35    /// - offset: `112`(x86)/`112`(x86_64)
36    /// - type_size: `  4`(x86)/`  4`(x86_64)
37    #[cfg_attr(feature = "json_schema", schemars(rename = "ang"))]
38    #[cfg_attr(feature = "serde", serde(rename = "ang"))]
39    pub m_ang: hkpAngConstraintAtom,
40}
41const _: () = {
42    use havok_serde as _serde;
43    impl _serde::HavokClass for hkpRotationalConstraintDataAtoms {
44        #[inline]
45        fn name(&self) -> &'static str {
46            "hkpRotationalConstraintDataAtoms"
47        }
48        #[inline]
49        fn signature(&self) -> _serde::__private::Signature {
50            _serde::__private::Signature::new(0xa0c64586)
51        }
52        #[allow(clippy::let_and_return, clippy::vec_init_then_push)]
53        fn deps_indexes(&self) -> Vec<usize> {
54            let mut v = Vec::new();
55            v.extend(self.m_rotations.deps_indexes());
56            v.extend(self.m_ang.deps_indexes());
57            v
58        }
59    }
60    impl _serde::Serialize for hkpRotationalConstraintDataAtoms {
61        fn serialize<S>(&self, __serializer: S) -> Result<S::Ok, S::Error>
62        where
63            S: _serde::ser::Serializer,
64        {
65            let class_meta = self
66                .__ptr
67                .map(|name| (name, _serde::__private::Signature::new(0xa0c64586)));
68            let mut serializer = __serializer
69                .serialize_struct(
70                    "hkpRotationalConstraintDataAtoms",
71                    class_meta,
72                    (128u64, 128u64),
73                )?;
74            serializer.serialize_field("rotations", &self.m_rotations)?;
75            serializer.serialize_field("ang", &self.m_ang)?;
76            serializer.pad_field([0u8; 12usize].as_slice(), [0u8; 12usize].as_slice())?;
77            serializer.end()
78        }
79    }
80};
81#[doc(hidden)]
82#[allow(non_upper_case_globals, unused_attributes, unused_qualifications)]
83const _: () = {
84    use havok_serde as _serde;
85    #[automatically_derived]
86    impl<'de> _serde::Deserialize<'de> for hkpRotationalConstraintDataAtoms {
87        fn deserialize<__D>(deserializer: __D) -> core::result::Result<Self, __D::Error>
88        where
89            __D: _serde::Deserializer<'de>,
90        {
91            #[allow(non_camel_case_types)]
92            enum __Field {
93                m_rotations,
94                m_ang,
95                __ignore,
96            }
97            struct __FieldVisitor;
98            impl<'de> _serde::de::Visitor<'de> for __FieldVisitor {
99                type Value = __Field;
100                fn expecting(
101                    &self,
102                    __formatter: &mut core::fmt::Formatter,
103                ) -> core::fmt::Result {
104                    core::fmt::Formatter::write_str(__formatter, "field identifier")
105                }
106                /// Intended for use in XML.
107                #[allow(clippy::match_single_binding)]
108                #[allow(clippy::reversed_empty_ranges)]
109                #[allow(clippy::single_match)]
110                fn visit_key<__E>(
111                    self,
112                    __value: &str,
113                ) -> core::result::Result<Self::Value, __E>
114                where
115                    __E: _serde::de::Error,
116                {
117                    match __value {
118                        "rotations" => Ok(__Field::m_rotations),
119                        "ang" => Ok(__Field::m_ang),
120                        _ => Ok(__Field::__ignore),
121                    }
122                }
123            }
124            impl<'de> _serde::Deserialize<'de> for __Field {
125                #[inline]
126                fn deserialize<__D>(
127                    __deserializer: __D,
128                ) -> core::result::Result<Self, __D::Error>
129                where
130                    __D: _serde::Deserializer<'de>,
131                {
132                    _serde::Deserializer::deserialize_key(__deserializer, __FieldVisitor)
133                }
134            }
135            struct __hkpRotationalConstraintDataAtomsVisitor<'de> {
136                marker: _serde::__private::PhantomData<hkpRotationalConstraintDataAtoms>,
137                lifetime: _serde::__private::PhantomData<&'de ()>,
138            }
139            #[allow(clippy::match_single_binding)]
140            #[allow(clippy::reversed_empty_ranges)]
141            #[allow(clippy::single_match)]
142            impl<'de> _serde::de::Visitor<'de>
143            for __hkpRotationalConstraintDataAtomsVisitor<'de> {
144                type Value = hkpRotationalConstraintDataAtoms;
145                fn expecting(
146                    &self,
147                    __formatter: &mut core::fmt::Formatter,
148                ) -> core::fmt::Result {
149                    core::fmt::Formatter::write_str(
150                        __formatter,
151                        "struct hkpRotationalConstraintDataAtoms",
152                    )
153                }
154                fn visit_struct_for_bytes<__A>(
155                    self,
156                    mut __map: __A,
157                ) -> _serde::__private::Result<Self::Value, __A::Error>
158                where
159                    __A: _serde::de::MapAccess<'de>,
160                {
161                    let __ptr = __A::class_ptr(&mut __map);
162                    let mut m_rotations: _serde::__private::Option<
163                        hkpSetLocalRotationsConstraintAtom,
164                    > = _serde::__private::None;
165                    let mut m_ang: _serde::__private::Option<hkpAngConstraintAtom> = _serde::__private::None;
166                    for i in 0..2usize {
167                        match i {
168                            0usize => {
169                                if _serde::__private::Option::is_some(&m_rotations) {
170                                    return _serde::__private::Err(
171                                        <__A::Error as _serde::de::Error>::duplicate_field(
172                                            "rotations",
173                                        ),
174                                    );
175                                }
176                                m_rotations = _serde::__private::Some(
177                                    match __A::next_value::<
178                                        hkpSetLocalRotationsConstraintAtom,
179                                    >(&mut __map) {
180                                        _serde::__private::Ok(__val) => __val,
181                                        _serde::__private::Err(__err) => {
182                                            return _serde::__private::Err(__err);
183                                        }
184                                    },
185                                );
186                            }
187                            1usize => {
188                                if _serde::__private::Option::is_some(&m_ang) {
189                                    return _serde::__private::Err(
190                                        <__A::Error as _serde::de::Error>::duplicate_field("ang"),
191                                    );
192                                }
193                                m_ang = _serde::__private::Some(
194                                    match __A::next_value::<hkpAngConstraintAtom>(&mut __map) {
195                                        _serde::__private::Ok(__val) => __val,
196                                        _serde::__private::Err(__err) => {
197                                            return _serde::__private::Err(__err);
198                                        }
199                                    },
200                                );
201                            }
202                            _ => {}
203                        }
204                    }
205                    __A::pad(&mut __map, 12usize, 12usize)?;
206                    let m_rotations = match m_rotations {
207                        _serde::__private::Some(__field) => __field,
208                        _serde::__private::None => {
209                            return _serde::__private::Err(
210                                <__A::Error as _serde::de::Error>::missing_field(
211                                    "rotations",
212                                ),
213                            );
214                        }
215                    };
216                    let m_ang = match m_ang {
217                        _serde::__private::Some(__field) => __field,
218                        _serde::__private::None => {
219                            return _serde::__private::Err(
220                                <__A::Error as _serde::de::Error>::missing_field("ang"),
221                            );
222                        }
223                    };
224                    _serde::__private::Ok(hkpRotationalConstraintDataAtoms {
225                        __ptr,
226                        m_rotations,
227                        m_ang,
228                    })
229                }
230                #[allow(clippy::manual_unwrap_or_default)]
231                fn visit_struct<__A>(
232                    self,
233                    mut __map: __A,
234                ) -> _serde::__private::Result<Self::Value, __A::Error>
235                where
236                    __A: _serde::de::MapAccess<'de>,
237                {
238                    let mut m_rotations: _serde::__private::Option<
239                        hkpSetLocalRotationsConstraintAtom,
240                    > = _serde::__private::None;
241                    let mut m_ang: _serde::__private::Option<hkpAngConstraintAtom> = _serde::__private::None;
242                    while let _serde::__private::Some(__key) = {
243                        __A::next_key::<__Field>(&mut __map)?
244                    } {
245                        match __key {
246                            __Field::m_rotations => {
247                                #[cfg(
248                                    any(feature = "strict", feature = "ignore_duplicates")
249                                )]
250                                if _serde::__private::Option::is_some(&m_rotations) {
251                                    #[cfg(feature = "ignore_duplicates")]
252                                    {
253                                        __A::skip_value(&mut __map)?;
254                                        continue;
255                                    }
256                                    #[cfg(feature = "strict")]
257                                    return _serde::__private::Err(
258                                        <__A::Error as _serde::de::Error>::duplicate_field(
259                                            "rotations",
260                                        ),
261                                    );
262                                }
263                                m_rotations = _serde::__private::Some(
264                                    match __A::next_value::<
265                                        hkpSetLocalRotationsConstraintAtom,
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                            __Field::m_ang => {
275                                #[cfg(
276                                    any(feature = "strict", feature = "ignore_duplicates")
277                                )]
278                                if _serde::__private::Option::is_some(&m_ang) {
279                                    #[cfg(feature = "ignore_duplicates")]
280                                    {
281                                        __A::skip_value(&mut __map)?;
282                                        continue;
283                                    }
284                                    #[cfg(feature = "strict")]
285                                    return _serde::__private::Err(
286                                        <__A::Error as _serde::de::Error>::duplicate_field("ang"),
287                                    );
288                                }
289                                m_ang = _serde::__private::Some(
290                                    match __A::next_value::<hkpAngConstraintAtom>(&mut __map) {
291                                        _serde::__private::Ok(__val) => __val,
292                                        _serde::__private::Err(__err) => {
293                                            return _serde::__private::Err(__err);
294                                        }
295                                    },
296                                );
297                            }
298                            _ => __A::skip_value(&mut __map)?,
299                        }
300                    }
301                    let m_rotations = match m_rotations {
302                        _serde::__private::Some(__field) => __field,
303                        _serde::__private::None => {
304                            #[cfg(feature = "strict")]
305                            return _serde::__private::Err(
306                                <__A::Error as _serde::de::Error>::missing_field(
307                                    "rotations",
308                                ),
309                            );
310                            #[cfg(not(feature = "strict"))] Default::default()
311                        }
312                    };
313                    let m_ang = match m_ang {
314                        _serde::__private::Some(__field) => __field,
315                        _serde::__private::None => {
316                            #[cfg(feature = "strict")]
317                            return _serde::__private::Err(
318                                <__A::Error as _serde::de::Error>::missing_field("ang"),
319                            );
320                            #[cfg(not(feature = "strict"))] Default::default()
321                        }
322                    };
323                    let __ptr = __A::class_ptr(&mut __map);
324                    _serde::__private::Ok(hkpRotationalConstraintDataAtoms {
325                        __ptr,
326                        m_rotations,
327                        m_ang,
328                    })
329                }
330            }
331            const FIELDS: &[&str] = &["rotations", "ang"];
332            _serde::Deserializer::deserialize_struct(
333                deserializer,
334                "hkpRotationalConstraintDataAtoms",
335                FIELDS,
336                __hkpRotationalConstraintDataAtomsVisitor {
337                    marker: _serde::__private::PhantomData::<
338                        hkpRotationalConstraintDataAtoms,
339                    >,
340                    lifetime: _serde::__private::PhantomData,
341                },
342            )
343        }
344    }
345};