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