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 hkpListShapeChildInfo {
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 = "shape"))]
32 #[cfg_attr(feature = "serde", serde(rename = "shape"))]
33 pub m_shape: Pointer,
34 #[cfg_attr(feature = "json_schema", schemars(rename = "collisionFilterInfo"))]
39 #[cfg_attr(feature = "serde", serde(rename = "collisionFilterInfo"))]
40 pub m_collisionFilterInfo: u32,
41 #[cfg_attr(feature = "json_schema", schemars(rename = "shapeSize"))]
47 #[cfg_attr(feature = "serde", serde(rename = "shapeSize"))]
48 pub m_shapeSize: i32,
49 #[cfg_attr(feature = "json_schema", schemars(rename = "numChildShapes"))]
55 #[cfg_attr(feature = "serde", serde(rename = "numChildShapes"))]
56 pub m_numChildShapes: i32,
57}
58const _: () = {
59 use havok_serde as _serde;
60 impl _serde::HavokClass for hkpListShapeChildInfo {
61 #[inline]
62 fn name(&self) -> &'static str {
63 "hkpListShapeChildInfo"
64 }
65 #[inline]
66 fn signature(&self) -> _serde::__private::Signature {
67 _serde::__private::Signature::new(0x80df0f90)
68 }
69 #[allow(clippy::let_and_return, clippy::vec_init_then_push)]
70 fn deps_indexes(&self) -> Vec<usize> {
71 let mut v = Vec::new();
72 v.push(self.m_shape.get());
73 v
74 }
75 }
76 impl _serde::Serialize for hkpListShapeChildInfo {
77 fn serialize<S>(&self, __serializer: S) -> Result<S::Ok, S::Error>
78 where
79 S: _serde::ser::Serializer,
80 {
81 let class_meta = self
82 .__ptr
83 .map(|name| (name, _serde::__private::Signature::new(0x80df0f90)));
84 let mut serializer = __serializer
85 .serialize_struct("hkpListShapeChildInfo", class_meta, (16u64, 32u64))?;
86 serializer.serialize_field("shape", &self.m_shape)?;
87 serializer
88 .serialize_field("collisionFilterInfo", &self.m_collisionFilterInfo)?;
89 serializer.skip_field("shapeSize", &self.m_shapeSize)?;
90 serializer.skip_field("numChildShapes", &self.m_numChildShapes)?;
91 serializer.pad_field([0u8; 0usize].as_slice(), [0u8; 12usize].as_slice())?;
92 serializer.end()
93 }
94 }
95};
96#[doc(hidden)]
97#[allow(non_upper_case_globals, unused_attributes, unused_qualifications)]
98const _: () = {
99 use havok_serde as _serde;
100 #[automatically_derived]
101 impl<'de> _serde::Deserialize<'de> for hkpListShapeChildInfo {
102 fn deserialize<__D>(deserializer: __D) -> core::result::Result<Self, __D::Error>
103 where
104 __D: _serde::Deserializer<'de>,
105 {
106 #[allow(non_camel_case_types)]
107 enum __Field {
108 m_shape,
109 m_collisionFilterInfo,
110 __ignore,
111 }
112 struct __FieldVisitor;
113 impl<'de> _serde::de::Visitor<'de> for __FieldVisitor {
114 type Value = __Field;
115 fn expecting(
116 &self,
117 __formatter: &mut core::fmt::Formatter,
118 ) -> core::fmt::Result {
119 core::fmt::Formatter::write_str(__formatter, "field identifier")
120 }
121 #[allow(clippy::match_single_binding)]
123 #[allow(clippy::reversed_empty_ranges)]
124 #[allow(clippy::single_match)]
125 fn visit_key<__E>(
126 self,
127 __value: &str,
128 ) -> core::result::Result<Self::Value, __E>
129 where
130 __E: _serde::de::Error,
131 {
132 match __value {
133 "shape" => Ok(__Field::m_shape),
134 "collisionFilterInfo" => Ok(__Field::m_collisionFilterInfo),
135 _ => Ok(__Field::__ignore),
136 }
137 }
138 }
139 impl<'de> _serde::Deserialize<'de> for __Field {
140 #[inline]
141 fn deserialize<__D>(
142 __deserializer: __D,
143 ) -> core::result::Result<Self, __D::Error>
144 where
145 __D: _serde::Deserializer<'de>,
146 {
147 _serde::Deserializer::deserialize_key(__deserializer, __FieldVisitor)
148 }
149 }
150 struct __hkpListShapeChildInfoVisitor<'de> {
151 marker: _serde::__private::PhantomData<hkpListShapeChildInfo>,
152 lifetime: _serde::__private::PhantomData<&'de ()>,
153 }
154 #[allow(clippy::match_single_binding)]
155 #[allow(clippy::reversed_empty_ranges)]
156 #[allow(clippy::single_match)]
157 impl<'de> _serde::de::Visitor<'de> for __hkpListShapeChildInfoVisitor<'de> {
158 type Value = hkpListShapeChildInfo;
159 fn expecting(
160 &self,
161 __formatter: &mut core::fmt::Formatter,
162 ) -> core::fmt::Result {
163 core::fmt::Formatter::write_str(
164 __formatter,
165 "struct hkpListShapeChildInfo",
166 )
167 }
168 fn visit_struct_for_bytes<__A>(
169 self,
170 mut __map: __A,
171 ) -> _serde::__private::Result<Self::Value, __A::Error>
172 where
173 __A: _serde::de::MapAccess<'de>,
174 {
175 let __ptr = __A::class_ptr(&mut __map);
176 let mut m_shape: _serde::__private::Option<Pointer> = _serde::__private::None;
177 let mut m_collisionFilterInfo: _serde::__private::Option<u32> = _serde::__private::None;
178 let mut m_shapeSize: _serde::__private::Option<i32> = _serde::__private::None;
179 let mut m_numChildShapes: _serde::__private::Option<i32> = _serde::__private::None;
180 for i in 0..4usize {
181 match i {
182 0usize => {
183 if _serde::__private::Option::is_some(&m_shape) {
184 return _serde::__private::Err(
185 <__A::Error as _serde::de::Error>::duplicate_field("shape"),
186 );
187 }
188 m_shape = _serde::__private::Some(
189 match __A::next_value::<Pointer>(&mut __map) {
190 _serde::__private::Ok(__val) => __val,
191 _serde::__private::Err(__err) => {
192 return _serde::__private::Err(__err);
193 }
194 },
195 );
196 }
197 1usize => {
198 if _serde::__private::Option::is_some(
199 &m_collisionFilterInfo,
200 ) {
201 return _serde::__private::Err(
202 <__A::Error as _serde::de::Error>::duplicate_field(
203 "collisionFilterInfo",
204 ),
205 );
206 }
207 m_collisionFilterInfo = _serde::__private::Some(
208 match __A::next_value::<u32>(&mut __map) {
209 _serde::__private::Ok(__val) => __val,
210 _serde::__private::Err(__err) => {
211 return _serde::__private::Err(__err);
212 }
213 },
214 );
215 }
216 2usize => {
217 if _serde::__private::Option::is_some(&m_shapeSize) {
218 return _serde::__private::Err(
219 <__A::Error as _serde::de::Error>::duplicate_field(
220 "shapeSize",
221 ),
222 );
223 }
224 m_shapeSize = _serde::__private::Some(
225 match __A::next_value::<i32>(&mut __map) {
226 _serde::__private::Ok(__val) => __val,
227 _serde::__private::Err(__err) => {
228 return _serde::__private::Err(__err);
229 }
230 },
231 );
232 }
233 3usize => {
234 if _serde::__private::Option::is_some(&m_numChildShapes) {
235 return _serde::__private::Err(
236 <__A::Error as _serde::de::Error>::duplicate_field(
237 "numChildShapes",
238 ),
239 );
240 }
241 m_numChildShapes = _serde::__private::Some(
242 match __A::next_value::<i32>(&mut __map) {
243 _serde::__private::Ok(__val) => __val,
244 _serde::__private::Err(__err) => {
245 return _serde::__private::Err(__err);
246 }
247 },
248 );
249 }
250 _ => {}
251 }
252 }
253 __A::pad(&mut __map, 0usize, 12usize)?;
254 let m_shape = match m_shape {
255 _serde::__private::Some(__field) => __field,
256 _serde::__private::None => {
257 return _serde::__private::Err(
258 <__A::Error as _serde::de::Error>::missing_field("shape"),
259 );
260 }
261 };
262 let m_collisionFilterInfo = match m_collisionFilterInfo {
263 _serde::__private::Some(__field) => __field,
264 _serde::__private::None => {
265 return _serde::__private::Err(
266 <__A::Error as _serde::de::Error>::missing_field(
267 "collisionFilterInfo",
268 ),
269 );
270 }
271 };
272 let m_shapeSize = match m_shapeSize {
273 _serde::__private::Some(__field) => __field,
274 _serde::__private::None => {
275 return _serde::__private::Err(
276 <__A::Error as _serde::de::Error>::missing_field(
277 "shapeSize",
278 ),
279 );
280 }
281 };
282 let m_numChildShapes = match m_numChildShapes {
283 _serde::__private::Some(__field) => __field,
284 _serde::__private::None => {
285 return _serde::__private::Err(
286 <__A::Error as _serde::de::Error>::missing_field(
287 "numChildShapes",
288 ),
289 );
290 }
291 };
292 _serde::__private::Ok(hkpListShapeChildInfo {
293 __ptr,
294 m_shape,
295 m_collisionFilterInfo,
296 m_shapeSize,
297 m_numChildShapes,
298 })
299 }
300 #[allow(clippy::manual_unwrap_or_default)]
301 fn visit_struct<__A>(
302 self,
303 mut __map: __A,
304 ) -> _serde::__private::Result<Self::Value, __A::Error>
305 where
306 __A: _serde::de::MapAccess<'de>,
307 {
308 let mut m_shape: _serde::__private::Option<Pointer> = _serde::__private::None;
309 let mut m_collisionFilterInfo: _serde::__private::Option<u32> = _serde::__private::None;
310 while let _serde::__private::Some(__key) = {
311 __A::next_key::<__Field>(&mut __map)?
312 } {
313 match __key {
314 __Field::m_shape => {
315 #[cfg(
316 any(feature = "strict", feature = "ignore_duplicates")
317 )]
318 if _serde::__private::Option::is_some(&m_shape) {
319 #[cfg(feature = "ignore_duplicates")]
320 {
321 __A::skip_value(&mut __map)?;
322 continue;
323 }
324 #[cfg(feature = "strict")]
325 return _serde::__private::Err(
326 <__A::Error as _serde::de::Error>::duplicate_field("shape"),
327 );
328 }
329 m_shape = _serde::__private::Some(
330 match __A::next_value::<Pointer>(&mut __map) {
331 _serde::__private::Ok(__val) => __val,
332 _serde::__private::Err(__err) => {
333 return _serde::__private::Err(__err);
334 }
335 },
336 );
337 }
338 __Field::m_collisionFilterInfo => {
339 #[cfg(
340 any(feature = "strict", feature = "ignore_duplicates")
341 )]
342 if _serde::__private::Option::is_some(
343 &m_collisionFilterInfo,
344 ) {
345 #[cfg(feature = "ignore_duplicates")]
346 {
347 __A::skip_value(&mut __map)?;
348 continue;
349 }
350 #[cfg(feature = "strict")]
351 return _serde::__private::Err(
352 <__A::Error as _serde::de::Error>::duplicate_field(
353 "collisionFilterInfo",
354 ),
355 );
356 }
357 m_collisionFilterInfo = _serde::__private::Some(
358 match __A::next_value::<u32>(&mut __map) {
359 _serde::__private::Ok(__val) => __val,
360 _serde::__private::Err(__err) => {
361 return _serde::__private::Err(__err);
362 }
363 },
364 );
365 }
366 _ => __A::skip_value(&mut __map)?,
367 }
368 }
369 let m_shape = match m_shape {
370 _serde::__private::Some(__field) => __field,
371 _serde::__private::None => {
372 #[cfg(feature = "strict")]
373 return _serde::__private::Err(
374 <__A::Error as _serde::de::Error>::missing_field("shape"),
375 );
376 #[cfg(not(feature = "strict"))] Default::default()
377 }
378 };
379 let m_collisionFilterInfo = match m_collisionFilterInfo {
380 _serde::__private::Some(__field) => __field,
381 _serde::__private::None => {
382 #[cfg(feature = "strict")]
383 return _serde::__private::Err(
384 <__A::Error as _serde::de::Error>::missing_field(
385 "collisionFilterInfo",
386 ),
387 );
388 #[cfg(not(feature = "strict"))] Default::default()
389 }
390 };
391 let __ptr = __A::class_ptr(&mut __map);
392 _serde::__private::Ok(hkpListShapeChildInfo {
393 __ptr,
394 m_shape,
395 m_collisionFilterInfo,
396 ..Default::default()
397 })
398 }
399 }
400 const FIELDS: &[&str] = &[
401 "shape",
402 "collisionFilterInfo",
403 "shapeSize",
404 "numChildShapes",
405 ];
406 _serde::Deserializer::deserialize_struct(
407 deserializer,
408 "hkpListShapeChildInfo",
409 FIELDS,
410 __hkpListShapeChildInfoVisitor {
411 marker: _serde::__private::PhantomData::<hkpListShapeChildInfo>,
412 lifetime: _serde::__private::PhantomData,
413 },
414 )
415 }
416 }
417};