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