havok_classes/generated/
hkpSpringDamperConstraintMotor_.rs

1use super::class_requires::*;
2use super::*;
3/// # C++ Info
4/// - name: `hkpSpringDamperConstraintMotor`
5/// - version: `0`
6/// - signature: `0x7ead26f6`
7/// - size: ` 28`(x86)/` 40`(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 hkpSpringDamperConstraintMotor {
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: hkpLimitedForceConstraintMotor,
30    /// # C++ Info
31    /// - name: `springConstant`(ctype: `hkReal`)
32    /// - offset: ` 20`(x86)/` 32`(x86_64)
33    /// - type_size: `  4`(x86)/`  4`(x86_64)
34    #[cfg_attr(feature = "json_schema", schemars(rename = "springConstant"))]
35    #[cfg_attr(feature = "serde", serde(rename = "springConstant"))]
36    pub m_springConstant: f32,
37    /// # C++ Info
38    /// - name: `springDamping`(ctype: `hkReal`)
39    /// - offset: ` 24`(x86)/` 36`(x86_64)
40    /// - type_size: `  4`(x86)/`  4`(x86_64)
41    #[cfg_attr(feature = "json_schema", schemars(rename = "springDamping"))]
42    #[cfg_attr(feature = "serde", serde(rename = "springDamping"))]
43    pub m_springDamping: f32,
44}
45const _: () = {
46    use havok_serde as _serde;
47    impl _serde::HavokClass for hkpSpringDamperConstraintMotor {
48        #[inline]
49        fn name(&self) -> &'static str {
50            "hkpSpringDamperConstraintMotor"
51        }
52        #[inline]
53        fn signature(&self) -> _serde::__private::Signature {
54            _serde::__private::Signature::new(0x7ead26f6)
55        }
56        #[allow(clippy::let_and_return, clippy::vec_init_then_push)]
57        fn deps_indexes(&self) -> Vec<usize> {
58            let mut v = Vec::new();
59            v
60        }
61    }
62    impl _serde::Serialize for hkpSpringDamperConstraintMotor {
63        fn serialize<S>(&self, __serializer: S) -> Result<S::Ok, S::Error>
64        where
65            S: _serde::ser::Serializer,
66        {
67            let class_meta = self
68                .__ptr
69                .map(|name| (name, _serde::__private::Signature::new(0x7ead26f6)));
70            let mut serializer = __serializer
71                .serialize_struct(
72                    "hkpSpringDamperConstraintMotor",
73                    class_meta,
74                    (28u64, 40u64),
75                )?;
76            serializer.pad_field([0u8; 4usize].as_slice(), [0u8; 8usize].as_slice())?;
77            serializer
78                .skip_field(
79                    "memSizeAndFlags",
80                    &self.parent.parent.parent.m_memSizeAndFlags,
81                )?;
82            serializer
83                .skip_field(
84                    "referenceCount",
85                    &self.parent.parent.parent.m_referenceCount,
86                )?;
87            serializer.pad_field([0u8; 0usize].as_slice(), [0u8; 4usize].as_slice())?;
88            serializer.serialize_field("type", &self.parent.parent.m_type)?;
89            serializer.pad_field([0u8; 3usize].as_slice(), [0u8; 7usize].as_slice())?;
90            serializer.serialize_field("minForce", &self.parent.m_minForce)?;
91            serializer.serialize_field("maxForce", &self.parent.m_maxForce)?;
92            serializer.serialize_field("springConstant", &self.m_springConstant)?;
93            serializer.serialize_field("springDamping", &self.m_springDamping)?;
94            serializer.end()
95        }
96    }
97};
98#[doc(hidden)]
99#[allow(non_upper_case_globals, unused_attributes, unused_qualifications)]
100const _: () = {
101    use havok_serde as _serde;
102    #[automatically_derived]
103    impl<'de> _serde::Deserialize<'de> for hkpSpringDamperConstraintMotor {
104        fn deserialize<__D>(deserializer: __D) -> core::result::Result<Self, __D::Error>
105        where
106            __D: _serde::Deserializer<'de>,
107        {
108            #[allow(non_camel_case_types)]
109            enum __Field {
110                m_type,
111                m_minForce,
112                m_maxForce,
113                m_springConstant,
114                m_springDamping,
115                __ignore,
116            }
117            struct __FieldVisitor;
118            impl<'de> _serde::de::Visitor<'de> for __FieldVisitor {
119                type Value = __Field;
120                fn expecting(
121                    &self,
122                    __formatter: &mut core::fmt::Formatter,
123                ) -> core::fmt::Result {
124                    core::fmt::Formatter::write_str(__formatter, "field identifier")
125                }
126                /// Intended for use in XML.
127                #[allow(clippy::match_single_binding)]
128                #[allow(clippy::reversed_empty_ranges)]
129                #[allow(clippy::single_match)]
130                fn visit_key<__E>(
131                    self,
132                    __value: &str,
133                ) -> core::result::Result<Self::Value, __E>
134                where
135                    __E: _serde::de::Error,
136                {
137                    match __value {
138                        "type" => Ok(__Field::m_type),
139                        "minForce" => Ok(__Field::m_minForce),
140                        "maxForce" => Ok(__Field::m_maxForce),
141                        "springConstant" => Ok(__Field::m_springConstant),
142                        "springDamping" => Ok(__Field::m_springDamping),
143                        _ => Ok(__Field::__ignore),
144                    }
145                }
146            }
147            impl<'de> _serde::Deserialize<'de> for __Field {
148                #[inline]
149                fn deserialize<__D>(
150                    __deserializer: __D,
151                ) -> core::result::Result<Self, __D::Error>
152                where
153                    __D: _serde::Deserializer<'de>,
154                {
155                    _serde::Deserializer::deserialize_key(__deserializer, __FieldVisitor)
156                }
157            }
158            struct __hkpSpringDamperConstraintMotorVisitor<'de> {
159                marker: _serde::__private::PhantomData<hkpSpringDamperConstraintMotor>,
160                lifetime: _serde::__private::PhantomData<&'de ()>,
161            }
162            #[allow(clippy::match_single_binding)]
163            #[allow(clippy::reversed_empty_ranges)]
164            #[allow(clippy::single_match)]
165            impl<'de> _serde::de::Visitor<'de>
166            for __hkpSpringDamperConstraintMotorVisitor<'de> {
167                type Value = hkpSpringDamperConstraintMotor;
168                fn expecting(
169                    &self,
170                    __formatter: &mut core::fmt::Formatter,
171                ) -> core::fmt::Result {
172                    core::fmt::Formatter::write_str(
173                        __formatter,
174                        "struct hkpSpringDamperConstraintMotor",
175                    )
176                }
177                fn visit_struct_for_bytes<__A>(
178                    self,
179                    mut __map: __A,
180                ) -> _serde::__private::Result<Self::Value, __A::Error>
181                where
182                    __A: _serde::de::MapAccess<'de>,
183                {
184                    let __ptr = __A::class_ptr(&mut __map);
185                    let parent = __A::parent_value(&mut __map)?;
186                    let mut m_springConstant: _serde::__private::Option<f32> = _serde::__private::None;
187                    let mut m_springDamping: _serde::__private::Option<f32> = _serde::__private::None;
188                    for i in 0..2usize {
189                        match i {
190                            0usize => {
191                                if _serde::__private::Option::is_some(&m_springConstant) {
192                                    return _serde::__private::Err(
193                                        <__A::Error as _serde::de::Error>::duplicate_field(
194                                            "springConstant",
195                                        ),
196                                    );
197                                }
198                                m_springConstant = _serde::__private::Some(
199                                    match __A::next_value::<f32>(&mut __map) {
200                                        _serde::__private::Ok(__val) => __val,
201                                        _serde::__private::Err(__err) => {
202                                            return _serde::__private::Err(__err);
203                                        }
204                                    },
205                                );
206                            }
207                            1usize => {
208                                if _serde::__private::Option::is_some(&m_springDamping) {
209                                    return _serde::__private::Err(
210                                        <__A::Error as _serde::de::Error>::duplicate_field(
211                                            "springDamping",
212                                        ),
213                                    );
214                                }
215                                m_springDamping = _serde::__private::Some(
216                                    match __A::next_value::<f32>(&mut __map) {
217                                        _serde::__private::Ok(__val) => __val,
218                                        _serde::__private::Err(__err) => {
219                                            return _serde::__private::Err(__err);
220                                        }
221                                    },
222                                );
223                            }
224                            _ => {}
225                        }
226                    }
227                    let m_springConstant = match m_springConstant {
228                        _serde::__private::Some(__field) => __field,
229                        _serde::__private::None => {
230                            return _serde::__private::Err(
231                                <__A::Error as _serde::de::Error>::missing_field(
232                                    "springConstant",
233                                ),
234                            );
235                        }
236                    };
237                    let m_springDamping = match m_springDamping {
238                        _serde::__private::Some(__field) => __field,
239                        _serde::__private::None => {
240                            return _serde::__private::Err(
241                                <__A::Error as _serde::de::Error>::missing_field(
242                                    "springDamping",
243                                ),
244                            );
245                        }
246                    };
247                    _serde::__private::Ok(hkpSpringDamperConstraintMotor {
248                        __ptr,
249                        parent,
250                        m_springConstant,
251                        m_springDamping,
252                    })
253                }
254                #[allow(clippy::manual_unwrap_or_default)]
255                fn visit_struct<__A>(
256                    self,
257                    mut __map: __A,
258                ) -> _serde::__private::Result<Self::Value, __A::Error>
259                where
260                    __A: _serde::de::MapAccess<'de>,
261                {
262                    let mut m_type: _serde::__private::Option<MotorType> = _serde::__private::None;
263                    let mut m_minForce: _serde::__private::Option<f32> = _serde::__private::None;
264                    let mut m_maxForce: _serde::__private::Option<f32> = _serde::__private::None;
265                    let mut m_springConstant: _serde::__private::Option<f32> = _serde::__private::None;
266                    let mut m_springDamping: _serde::__private::Option<f32> = _serde::__private::None;
267                    while let _serde::__private::Some(__key) = {
268                        __A::next_key::<__Field>(&mut __map)?
269                    } {
270                        match __key {
271                            __Field::m_type => {
272                                #[cfg(
273                                    any(feature = "strict", feature = "ignore_duplicates")
274                                )]
275                                if _serde::__private::Option::is_some(&m_type) {
276                                    #[cfg(feature = "ignore_duplicates")]
277                                    {
278                                        __A::skip_value(&mut __map)?;
279                                        continue;
280                                    }
281                                    #[cfg(feature = "strict")]
282                                    return _serde::__private::Err(
283                                        <__A::Error as _serde::de::Error>::duplicate_field("type"),
284                                    );
285                                }
286                                m_type = _serde::__private::Some(
287                                    match __A::next_value::<MotorType>(&mut __map) {
288                                        _serde::__private::Ok(__val) => __val,
289                                        _serde::__private::Err(__err) => {
290                                            return _serde::__private::Err(__err);
291                                        }
292                                    },
293                                );
294                            }
295                            __Field::m_minForce => {
296                                #[cfg(
297                                    any(feature = "strict", feature = "ignore_duplicates")
298                                )]
299                                if _serde::__private::Option::is_some(&m_minForce) {
300                                    #[cfg(feature = "ignore_duplicates")]
301                                    {
302                                        __A::skip_value(&mut __map)?;
303                                        continue;
304                                    }
305                                    #[cfg(feature = "strict")]
306                                    return _serde::__private::Err(
307                                        <__A::Error as _serde::de::Error>::duplicate_field(
308                                            "minForce",
309                                        ),
310                                    );
311                                }
312                                m_minForce = _serde::__private::Some(
313                                    match __A::next_value::<f32>(&mut __map) {
314                                        _serde::__private::Ok(__val) => __val,
315                                        _serde::__private::Err(__err) => {
316                                            return _serde::__private::Err(__err);
317                                        }
318                                    },
319                                );
320                            }
321                            __Field::m_maxForce => {
322                                #[cfg(
323                                    any(feature = "strict", feature = "ignore_duplicates")
324                                )]
325                                if _serde::__private::Option::is_some(&m_maxForce) {
326                                    #[cfg(feature = "ignore_duplicates")]
327                                    {
328                                        __A::skip_value(&mut __map)?;
329                                        continue;
330                                    }
331                                    #[cfg(feature = "strict")]
332                                    return _serde::__private::Err(
333                                        <__A::Error as _serde::de::Error>::duplicate_field(
334                                            "maxForce",
335                                        ),
336                                    );
337                                }
338                                m_maxForce = _serde::__private::Some(
339                                    match __A::next_value::<f32>(&mut __map) {
340                                        _serde::__private::Ok(__val) => __val,
341                                        _serde::__private::Err(__err) => {
342                                            return _serde::__private::Err(__err);
343                                        }
344                                    },
345                                );
346                            }
347                            __Field::m_springConstant => {
348                                #[cfg(
349                                    any(feature = "strict", feature = "ignore_duplicates")
350                                )]
351                                if _serde::__private::Option::is_some(&m_springConstant) {
352                                    #[cfg(feature = "ignore_duplicates")]
353                                    {
354                                        __A::skip_value(&mut __map)?;
355                                        continue;
356                                    }
357                                    #[cfg(feature = "strict")]
358                                    return _serde::__private::Err(
359                                        <__A::Error as _serde::de::Error>::duplicate_field(
360                                            "springConstant",
361                                        ),
362                                    );
363                                }
364                                m_springConstant = _serde::__private::Some(
365                                    match __A::next_value::<f32>(&mut __map) {
366                                        _serde::__private::Ok(__val) => __val,
367                                        _serde::__private::Err(__err) => {
368                                            return _serde::__private::Err(__err);
369                                        }
370                                    },
371                                );
372                            }
373                            __Field::m_springDamping => {
374                                #[cfg(
375                                    any(feature = "strict", feature = "ignore_duplicates")
376                                )]
377                                if _serde::__private::Option::is_some(&m_springDamping) {
378                                    #[cfg(feature = "ignore_duplicates")]
379                                    {
380                                        __A::skip_value(&mut __map)?;
381                                        continue;
382                                    }
383                                    #[cfg(feature = "strict")]
384                                    return _serde::__private::Err(
385                                        <__A::Error as _serde::de::Error>::duplicate_field(
386                                            "springDamping",
387                                        ),
388                                    );
389                                }
390                                m_springDamping = _serde::__private::Some(
391                                    match __A::next_value::<f32>(&mut __map) {
392                                        _serde::__private::Ok(__val) => __val,
393                                        _serde::__private::Err(__err) => {
394                                            return _serde::__private::Err(__err);
395                                        }
396                                    },
397                                );
398                            }
399                            _ => __A::skip_value(&mut __map)?,
400                        }
401                    }
402                    let m_type = match m_type {
403                        _serde::__private::Some(__field) => __field,
404                        _serde::__private::None => {
405                            #[cfg(feature = "strict")]
406                            return _serde::__private::Err(
407                                <__A::Error as _serde::de::Error>::missing_field("type"),
408                            );
409                            #[cfg(not(feature = "strict"))] Default::default()
410                        }
411                    };
412                    let m_minForce = match m_minForce {
413                        _serde::__private::Some(__field) => __field,
414                        _serde::__private::None => {
415                            #[cfg(feature = "strict")]
416                            return _serde::__private::Err(
417                                <__A::Error as _serde::de::Error>::missing_field("minForce"),
418                            );
419                            #[cfg(not(feature = "strict"))] Default::default()
420                        }
421                    };
422                    let m_maxForce = match m_maxForce {
423                        _serde::__private::Some(__field) => __field,
424                        _serde::__private::None => {
425                            #[cfg(feature = "strict")]
426                            return _serde::__private::Err(
427                                <__A::Error as _serde::de::Error>::missing_field("maxForce"),
428                            );
429                            #[cfg(not(feature = "strict"))] Default::default()
430                        }
431                    };
432                    let m_springConstant = match m_springConstant {
433                        _serde::__private::Some(__field) => __field,
434                        _serde::__private::None => {
435                            #[cfg(feature = "strict")]
436                            return _serde::__private::Err(
437                                <__A::Error as _serde::de::Error>::missing_field(
438                                    "springConstant",
439                                ),
440                            );
441                            #[cfg(not(feature = "strict"))] Default::default()
442                        }
443                    };
444                    let m_springDamping = match m_springDamping {
445                        _serde::__private::Some(__field) => __field,
446                        _serde::__private::None => {
447                            #[cfg(feature = "strict")]
448                            return _serde::__private::Err(
449                                <__A::Error as _serde::de::Error>::missing_field(
450                                    "springDamping",
451                                ),
452                            );
453                            #[cfg(not(feature = "strict"))] Default::default()
454                        }
455                    };
456                    let __ptr = None;
457                    let parent = hkBaseObject { __ptr };
458                    let parent = hkReferencedObject {
459                        __ptr,
460                        parent,
461                        ..Default::default()
462                    };
463                    let parent = hkpConstraintMotor {
464                        __ptr,
465                        parent,
466                        m_type,
467                    };
468                    let parent = hkpLimitedForceConstraintMotor {
469                        __ptr,
470                        parent,
471                        m_minForce,
472                        m_maxForce,
473                    };
474                    let __ptr = __A::class_ptr(&mut __map);
475                    _serde::__private::Ok(hkpSpringDamperConstraintMotor {
476                        __ptr,
477                        parent,
478                        m_springConstant,
479                        m_springDamping,
480                    })
481                }
482            }
483            const FIELDS: &[&str] = &["springConstant", "springDamping"];
484            _serde::Deserializer::deserialize_struct(
485                deserializer,
486                "hkpSpringDamperConstraintMotor",
487                FIELDS,
488                __hkpSpringDamperConstraintMotorVisitor {
489                    marker: _serde::__private::PhantomData::<
490                        hkpSpringDamperConstraintMotor,
491                    >,
492                    lifetime: _serde::__private::PhantomData,
493                },
494            )
495        }
496    }
497};