havok_classes/generated/
hkpPoweredChainMapperTarget_.rs

1use super::class_requires::*;
2use super::*;
3/// # C++ Info
4/// - name: `hkpPoweredChainMapperTarget`
5/// - version: `0`
6/// - signature: `0xf651c74d`
7/// - size: `  8`(x86)/` 16`(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 hkpPoweredChainMapperTarget {
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: `chain`(ctype: `struct hkpPoweredChainData*`)
28    /// - offset: `  0`(x86)/`  0`(x86_64)
29    /// - type_size: `  4`(x86)/`  8`(x86_64)
30    #[cfg_attr(feature = "json_schema", schemars(rename = "chain"))]
31    #[cfg_attr(feature = "serde", serde(rename = "chain"))]
32    pub m_chain: Pointer,
33    /// # C++ Info
34    /// - name: `infoIndex`(ctype: `hkInt32`)
35    /// - offset: `  4`(x86)/`  8`(x86_64)
36    /// - type_size: `  4`(x86)/`  4`(x86_64)
37    #[cfg_attr(feature = "json_schema", schemars(rename = "infoIndex"))]
38    #[cfg_attr(feature = "serde", serde(rename = "infoIndex"))]
39    pub m_infoIndex: i32,
40}
41const _: () = {
42    use havok_serde as _serde;
43    impl _serde::HavokClass for hkpPoweredChainMapperTarget {
44        #[inline]
45        fn name(&self) -> &'static str {
46            "hkpPoweredChainMapperTarget"
47        }
48        #[inline]
49        fn signature(&self) -> _serde::__private::Signature {
50            _serde::__private::Signature::new(0xf651c74d)
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.push(self.m_chain.get());
56            v
57        }
58    }
59    impl _serde::Serialize for hkpPoweredChainMapperTarget {
60        fn serialize<S>(&self, __serializer: S) -> Result<S::Ok, S::Error>
61        where
62            S: _serde::ser::Serializer,
63        {
64            let class_meta = self
65                .__ptr
66                .map(|name| (name, _serde::__private::Signature::new(0xf651c74d)));
67            let mut serializer = __serializer
68                .serialize_struct(
69                    "hkpPoweredChainMapperTarget",
70                    class_meta,
71                    (8u64, 16u64),
72                )?;
73            serializer.serialize_field("chain", &self.m_chain)?;
74            serializer.serialize_field("infoIndex", &self.m_infoIndex)?;
75            serializer.pad_field([0u8; 0usize].as_slice(), [0u8; 4usize].as_slice())?;
76            serializer.end()
77        }
78    }
79};
80#[doc(hidden)]
81#[allow(non_upper_case_globals, unused_attributes, unused_qualifications)]
82const _: () = {
83    use havok_serde as _serde;
84    #[automatically_derived]
85    impl<'de> _serde::Deserialize<'de> for hkpPoweredChainMapperTarget {
86        fn deserialize<__D>(deserializer: __D) -> core::result::Result<Self, __D::Error>
87        where
88            __D: _serde::Deserializer<'de>,
89        {
90            #[allow(non_camel_case_types)]
91            enum __Field {
92                m_chain,
93                m_infoIndex,
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                        "chain" => Ok(__Field::m_chain),
118                        "infoIndex" => Ok(__Field::m_infoIndex),
119                        _ => Ok(__Field::__ignore),
120                    }
121                }
122            }
123            impl<'de> _serde::Deserialize<'de> for __Field {
124                #[inline]
125                fn deserialize<__D>(
126                    __deserializer: __D,
127                ) -> core::result::Result<Self, __D::Error>
128                where
129                    __D: _serde::Deserializer<'de>,
130                {
131                    _serde::Deserializer::deserialize_key(__deserializer, __FieldVisitor)
132                }
133            }
134            struct __hkpPoweredChainMapperTargetVisitor<'de> {
135                marker: _serde::__private::PhantomData<hkpPoweredChainMapperTarget>,
136                lifetime: _serde::__private::PhantomData<&'de ()>,
137            }
138            #[allow(clippy::match_single_binding)]
139            #[allow(clippy::reversed_empty_ranges)]
140            #[allow(clippy::single_match)]
141            impl<'de> _serde::de::Visitor<'de>
142            for __hkpPoweredChainMapperTargetVisitor<'de> {
143                type Value = hkpPoweredChainMapperTarget;
144                fn expecting(
145                    &self,
146                    __formatter: &mut core::fmt::Formatter,
147                ) -> core::fmt::Result {
148                    core::fmt::Formatter::write_str(
149                        __formatter,
150                        "struct hkpPoweredChainMapperTarget",
151                    )
152                }
153                fn visit_struct_for_bytes<__A>(
154                    self,
155                    mut __map: __A,
156                ) -> _serde::__private::Result<Self::Value, __A::Error>
157                where
158                    __A: _serde::de::MapAccess<'de>,
159                {
160                    let __ptr = __A::class_ptr(&mut __map);
161                    let mut m_chain: _serde::__private::Option<Pointer> = _serde::__private::None;
162                    let mut m_infoIndex: _serde::__private::Option<i32> = _serde::__private::None;
163                    for i in 0..2usize {
164                        match i {
165                            0usize => {
166                                if _serde::__private::Option::is_some(&m_chain) {
167                                    return _serde::__private::Err(
168                                        <__A::Error as _serde::de::Error>::duplicate_field("chain"),
169                                    );
170                                }
171                                m_chain = _serde::__private::Some(
172                                    match __A::next_value::<Pointer>(&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_infoIndex) {
182                                    return _serde::__private::Err(
183                                        <__A::Error as _serde::de::Error>::duplicate_field(
184                                            "infoIndex",
185                                        ),
186                                    );
187                                }
188                                m_infoIndex = _serde::__private::Some(
189                                    match __A::next_value::<i32>(&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_chain = match m_chain {
202                        _serde::__private::Some(__field) => __field,
203                        _serde::__private::None => {
204                            return _serde::__private::Err(
205                                <__A::Error as _serde::de::Error>::missing_field("chain"),
206                            );
207                        }
208                    };
209                    let m_infoIndex = match m_infoIndex {
210                        _serde::__private::Some(__field) => __field,
211                        _serde::__private::None => {
212                            return _serde::__private::Err(
213                                <__A::Error as _serde::de::Error>::missing_field(
214                                    "infoIndex",
215                                ),
216                            );
217                        }
218                    };
219                    _serde::__private::Ok(hkpPoweredChainMapperTarget {
220                        __ptr,
221                        m_chain,
222                        m_infoIndex,
223                    })
224                }
225                #[allow(clippy::manual_unwrap_or_default)]
226                fn visit_struct<__A>(
227                    self,
228                    mut __map: __A,
229                ) -> _serde::__private::Result<Self::Value, __A::Error>
230                where
231                    __A: _serde::de::MapAccess<'de>,
232                {
233                    let mut m_chain: _serde::__private::Option<Pointer> = _serde::__private::None;
234                    let mut m_infoIndex: _serde::__private::Option<i32> = _serde::__private::None;
235                    while let _serde::__private::Some(__key) = {
236                        __A::next_key::<__Field>(&mut __map)?
237                    } {
238                        match __key {
239                            __Field::m_chain => {
240                                #[cfg(
241                                    any(feature = "strict", feature = "ignore_duplicates")
242                                )]
243                                if _serde::__private::Option::is_some(&m_chain) {
244                                    #[cfg(feature = "ignore_duplicates")]
245                                    {
246                                        __A::skip_value(&mut __map)?;
247                                        continue;
248                                    }
249                                    #[cfg(feature = "strict")]
250                                    return _serde::__private::Err(
251                                        <__A::Error as _serde::de::Error>::duplicate_field("chain"),
252                                    );
253                                }
254                                m_chain = _serde::__private::Some(
255                                    match __A::next_value::<Pointer>(&mut __map) {
256                                        _serde::__private::Ok(__val) => __val,
257                                        _serde::__private::Err(__err) => {
258                                            return _serde::__private::Err(__err);
259                                        }
260                                    },
261                                );
262                            }
263                            __Field::m_infoIndex => {
264                                #[cfg(
265                                    any(feature = "strict", feature = "ignore_duplicates")
266                                )]
267                                if _serde::__private::Option::is_some(&m_infoIndex) {
268                                    #[cfg(feature = "ignore_duplicates")]
269                                    {
270                                        __A::skip_value(&mut __map)?;
271                                        continue;
272                                    }
273                                    #[cfg(feature = "strict")]
274                                    return _serde::__private::Err(
275                                        <__A::Error as _serde::de::Error>::duplicate_field(
276                                            "infoIndex",
277                                        ),
278                                    );
279                                }
280                                m_infoIndex = _serde::__private::Some(
281                                    match __A::next_value::<i32>(&mut __map) {
282                                        _serde::__private::Ok(__val) => __val,
283                                        _serde::__private::Err(__err) => {
284                                            return _serde::__private::Err(__err);
285                                        }
286                                    },
287                                );
288                            }
289                            _ => __A::skip_value(&mut __map)?,
290                        }
291                    }
292                    let m_chain = match m_chain {
293                        _serde::__private::Some(__field) => __field,
294                        _serde::__private::None => {
295                            #[cfg(feature = "strict")]
296                            return _serde::__private::Err(
297                                <__A::Error as _serde::de::Error>::missing_field("chain"),
298                            );
299                            #[cfg(not(feature = "strict"))] Default::default()
300                        }
301                    };
302                    let m_infoIndex = match m_infoIndex {
303                        _serde::__private::Some(__field) => __field,
304                        _serde::__private::None => {
305                            #[cfg(feature = "strict")]
306                            return _serde::__private::Err(
307                                <__A::Error as _serde::de::Error>::missing_field(
308                                    "infoIndex",
309                                ),
310                            );
311                            #[cfg(not(feature = "strict"))] Default::default()
312                        }
313                    };
314                    let __ptr = __A::class_ptr(&mut __map);
315                    _serde::__private::Ok(hkpPoweredChainMapperTarget {
316                        __ptr,
317                        m_chain,
318                        m_infoIndex,
319                    })
320                }
321            }
322            const FIELDS: &[&str] = &["chain", "infoIndex"];
323            _serde::Deserializer::deserialize_struct(
324                deserializer,
325                "hkpPoweredChainMapperTarget",
326                FIELDS,
327                __hkpPoweredChainMapperTargetVisitor {
328                    marker: _serde::__private::PhantomData::<
329                        hkpPoweredChainMapperTarget,
330                    >,
331                    lifetime: _serde::__private::PhantomData,
332                },
333            )
334        }
335    }
336};