1use super::class_requires::*;
2use super::*;
3#[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 #[cfg_attr(
22 feature = "serde",
23 serde(skip_serializing_if = "Option::is_none", default)
24 )]
25 pub __ptr: Option<Pointer>,
26 #[cfg_attr(feature = "json_schema", schemars(rename = "chain"))]
31 #[cfg_attr(feature = "serde", serde(rename = "chain"))]
32 pub m_chain: Pointer,
33 #[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 #[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};