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 hkbNode<'a> {
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: hkbBindable,
30 #[cfg_attr(feature = "json_schema", schemars(rename = "userData"))]
35 #[cfg_attr(feature = "serde", serde(rename = "userData"))]
36 pub m_userData: Ulong,
37 #[cfg_attr(feature = "serde", serde(borrow))]
42 #[cfg_attr(feature = "json_schema", schemars(rename = "name"))]
43 #[cfg_attr(feature = "serde", serde(rename = "name"))]
44 pub m_name: StringPtr<'a>,
45 #[cfg_attr(feature = "json_schema", schemars(rename = "id"))]
51 #[cfg_attr(feature = "serde", serde(rename = "id"))]
52 pub m_id: i16,
53 #[cfg_attr(feature = "json_schema", schemars(rename = "cloneState"))]
59 #[cfg_attr(feature = "serde", serde(rename = "cloneState"))]
60 pub m_cloneState: i8,
61 #[cfg_attr(feature = "json_schema", schemars(rename = "padNode"))]
67 #[cfg_attr(feature = "serde", serde(rename = "padNode"))]
68 pub m_padNode: [bool; 1usize],
69}
70const _: () = {
71 use havok_serde as _serde;
72 impl<'a> _serde::HavokClass for hkbNode<'a> {
73 #[inline]
74 fn name(&self) -> &'static str {
75 "hkbNode"
76 }
77 #[inline]
78 fn signature(&self) -> _serde::__private::Signature {
79 _serde::__private::Signature::new(0x6d26f61d)
80 }
81 #[allow(clippy::let_and_return, clippy::vec_init_then_push)]
82 fn deps_indexes(&self) -> Vec<usize> {
83 let mut v = Vec::new();
84 v.push(self.parent.m_variableBindingSet.get());
85 v
86 }
87 }
88 impl<'a> _serde::Serialize for hkbNode<'a> {
89 fn serialize<S>(&self, __serializer: S) -> Result<S::Ok, S::Error>
90 where
91 S: _serde::ser::Serializer,
92 {
93 let class_meta = self
94 .__ptr
95 .map(|name| (name, _serde::__private::Signature::new(0x6d26f61d)));
96 let mut serializer = __serializer
97 .serialize_struct("hkbNode", class_meta, (40u64, 72u64))?;
98 serializer.pad_field([0u8; 4usize].as_slice(), [0u8; 8usize].as_slice())?;
99 serializer
100 .skip_field("memSizeAndFlags", &self.parent.parent.m_memSizeAndFlags)?;
101 serializer
102 .skip_field("referenceCount", &self.parent.parent.m_referenceCount)?;
103 serializer.pad_field([0u8; 0usize].as_slice(), [0u8; 4usize].as_slice())?;
104 serializer
105 .serialize_field(
106 "variableBindingSet",
107 &self.parent.m_variableBindingSet,
108 )?;
109 serializer
110 .skip_array_field(
111 "cachedBindables",
112 &self.parent.m_cachedBindables,
113 TypeSize::NonPtr,
114 )?;
115 serializer
116 .skip_field("areBindablesCached", &self.parent.m_areBindablesCached)?;
117 serializer.pad_field([0u8; 3usize].as_slice(), [0u8; 7usize].as_slice())?;
118 serializer.serialize_field("userData", &self.m_userData)?;
119 serializer.serialize_field("name", &self.m_name)?;
120 serializer.skip_field("id", &self.m_id)?;
121 serializer.skip_field("cloneState", &self.m_cloneState)?;
122 serializer
123 .skip_fixed_array_field(
124 "padNode",
125 self.m_padNode.as_slice(),
126 TypeSize::NonPtr,
127 )?;
128 serializer.pad_field([0u8; 0usize].as_slice(), [0u8; 4usize].as_slice())?;
129 serializer.end()
130 }
131 }
132};
133#[doc(hidden)]
134#[allow(non_upper_case_globals, unused_attributes, unused_qualifications)]
135const _: () = {
136 use havok_serde as _serde;
137 #[automatically_derived]
138 impl<'de> _serde::Deserialize<'de> for hkbNode<'de> {
139 fn deserialize<__D>(deserializer: __D) -> core::result::Result<Self, __D::Error>
140 where
141 __D: _serde::Deserializer<'de>,
142 {
143 #[allow(non_camel_case_types)]
144 enum __Field {
145 m_variableBindingSet,
146 m_userData,
147 m_name,
148 __ignore,
149 }
150 struct __FieldVisitor;
151 impl<'de> _serde::de::Visitor<'de> for __FieldVisitor {
152 type Value = __Field;
153 fn expecting(
154 &self,
155 __formatter: &mut core::fmt::Formatter,
156 ) -> core::fmt::Result {
157 core::fmt::Formatter::write_str(__formatter, "field identifier")
158 }
159 #[allow(clippy::match_single_binding)]
161 #[allow(clippy::reversed_empty_ranges)]
162 #[allow(clippy::single_match)]
163 fn visit_key<__E>(
164 self,
165 __value: &str,
166 ) -> core::result::Result<Self::Value, __E>
167 where
168 __E: _serde::de::Error,
169 {
170 match __value {
171 "variableBindingSet" => Ok(__Field::m_variableBindingSet),
172 "userData" => Ok(__Field::m_userData),
173 "name" => Ok(__Field::m_name),
174 _ => Ok(__Field::__ignore),
175 }
176 }
177 }
178 impl<'de> _serde::Deserialize<'de> for __Field {
179 #[inline]
180 fn deserialize<__D>(
181 __deserializer: __D,
182 ) -> core::result::Result<Self, __D::Error>
183 where
184 __D: _serde::Deserializer<'de>,
185 {
186 _serde::Deserializer::deserialize_key(__deserializer, __FieldVisitor)
187 }
188 }
189 struct __hkbNodeVisitor<'de> {
190 marker: _serde::__private::PhantomData<hkbNode<'de>>,
191 lifetime: _serde::__private::PhantomData<&'de ()>,
192 }
193 #[allow(clippy::match_single_binding)]
194 #[allow(clippy::reversed_empty_ranges)]
195 #[allow(clippy::single_match)]
196 impl<'de> _serde::de::Visitor<'de> for __hkbNodeVisitor<'de> {
197 type Value = hkbNode<'de>;
198 fn expecting(
199 &self,
200 __formatter: &mut core::fmt::Formatter,
201 ) -> core::fmt::Result {
202 core::fmt::Formatter::write_str(__formatter, "struct hkbNode")
203 }
204 fn visit_struct_for_bytes<__A>(
205 self,
206 mut __map: __A,
207 ) -> _serde::__private::Result<Self::Value, __A::Error>
208 where
209 __A: _serde::de::MapAccess<'de>,
210 {
211 let __ptr = __A::class_ptr(&mut __map);
212 let parent = __A::parent_value(&mut __map)?;
213 let mut m_userData: _serde::__private::Option<Ulong> = _serde::__private::None;
214 let mut m_name: _serde::__private::Option<StringPtr<'de>> = _serde::__private::None;
215 let mut m_id: _serde::__private::Option<i16> = _serde::__private::None;
216 let mut m_cloneState: _serde::__private::Option<i8> = _serde::__private::None;
217 let mut m_padNode: _serde::__private::Option<[bool; 1usize]> = _serde::__private::None;
218 for i in 0..5usize {
219 match i {
220 0usize => {
221 if _serde::__private::Option::is_some(&m_userData) {
222 return _serde::__private::Err(
223 <__A::Error as _serde::de::Error>::duplicate_field(
224 "userData",
225 ),
226 );
227 }
228 m_userData = _serde::__private::Some(
229 match __A::next_value::<Ulong>(&mut __map) {
230 _serde::__private::Ok(__val) => __val,
231 _serde::__private::Err(__err) => {
232 return _serde::__private::Err(__err);
233 }
234 },
235 );
236 }
237 1usize => {
238 if _serde::__private::Option::is_some(&m_name) {
239 return _serde::__private::Err(
240 <__A::Error as _serde::de::Error>::duplicate_field("name"),
241 );
242 }
243 m_name = _serde::__private::Some(
244 match __A::next_value::<StringPtr<'de>>(&mut __map) {
245 _serde::__private::Ok(__val) => __val,
246 _serde::__private::Err(__err) => {
247 return _serde::__private::Err(__err);
248 }
249 },
250 );
251 }
252 2usize => {
253 if _serde::__private::Option::is_some(&m_id) {
254 return _serde::__private::Err(
255 <__A::Error as _serde::de::Error>::duplicate_field("id"),
256 );
257 }
258 m_id = _serde::__private::Some(
259 match __A::next_value::<i16>(&mut __map) {
260 _serde::__private::Ok(__val) => __val,
261 _serde::__private::Err(__err) => {
262 return _serde::__private::Err(__err);
263 }
264 },
265 );
266 }
267 3usize => {
268 if _serde::__private::Option::is_some(&m_cloneState) {
269 return _serde::__private::Err(
270 <__A::Error as _serde::de::Error>::duplicate_field(
271 "cloneState",
272 ),
273 );
274 }
275 m_cloneState = _serde::__private::Some(
276 match __A::next_value::<i8>(&mut __map) {
277 _serde::__private::Ok(__val) => __val,
278 _serde::__private::Err(__err) => {
279 return _serde::__private::Err(__err);
280 }
281 },
282 );
283 }
284 4usize => {
285 if _serde::__private::Option::is_some(&m_padNode) {
286 return _serde::__private::Err(
287 <__A::Error as _serde::de::Error>::duplicate_field(
288 "padNode",
289 ),
290 );
291 }
292 m_padNode = _serde::__private::Some(
293 match __A::next_value::<[bool; 1usize]>(&mut __map) {
294 _serde::__private::Ok(__val) => __val,
295 _serde::__private::Err(__err) => {
296 return _serde::__private::Err(__err);
297 }
298 },
299 );
300 }
301 _ => {}
302 }
303 }
304 __A::pad(&mut __map, 0usize, 4usize)?;
305 let m_userData = match m_userData {
306 _serde::__private::Some(__field) => __field,
307 _serde::__private::None => {
308 return _serde::__private::Err(
309 <__A::Error as _serde::de::Error>::missing_field("userData"),
310 );
311 }
312 };
313 let m_name = match m_name {
314 _serde::__private::Some(__field) => __field,
315 _serde::__private::None => {
316 return _serde::__private::Err(
317 <__A::Error as _serde::de::Error>::missing_field("name"),
318 );
319 }
320 };
321 let m_id = match m_id {
322 _serde::__private::Some(__field) => __field,
323 _serde::__private::None => {
324 return _serde::__private::Err(
325 <__A::Error as _serde::de::Error>::missing_field("id"),
326 );
327 }
328 };
329 let m_cloneState = match m_cloneState {
330 _serde::__private::Some(__field) => __field,
331 _serde::__private::None => {
332 return _serde::__private::Err(
333 <__A::Error as _serde::de::Error>::missing_field(
334 "cloneState",
335 ),
336 );
337 }
338 };
339 let m_padNode = match m_padNode {
340 _serde::__private::Some(__field) => __field,
341 _serde::__private::None => {
342 return _serde::__private::Err(
343 <__A::Error as _serde::de::Error>::missing_field("padNode"),
344 );
345 }
346 };
347 _serde::__private::Ok(hkbNode {
348 __ptr,
349 parent,
350 m_userData,
351 m_name,
352 m_id,
353 m_cloneState,
354 m_padNode,
355 })
356 }
357 #[allow(clippy::manual_unwrap_or_default)]
358 fn visit_struct<__A>(
359 self,
360 mut __map: __A,
361 ) -> _serde::__private::Result<Self::Value, __A::Error>
362 where
363 __A: _serde::de::MapAccess<'de>,
364 {
365 let mut m_variableBindingSet: _serde::__private::Option<Pointer> = _serde::__private::None;
366 let mut m_userData: _serde::__private::Option<Ulong> = _serde::__private::None;
367 let mut m_name: _serde::__private::Option<StringPtr<'de>> = _serde::__private::None;
368 while let _serde::__private::Some(__key) = {
369 __A::next_key::<__Field>(&mut __map)?
370 } {
371 match __key {
372 __Field::m_variableBindingSet => {
373 #[cfg(
374 any(feature = "strict", feature = "ignore_duplicates")
375 )]
376 if _serde::__private::Option::is_some(
377 &m_variableBindingSet,
378 ) {
379 #[cfg(feature = "ignore_duplicates")]
380 {
381 __A::skip_value(&mut __map)?;
382 continue;
383 }
384 #[cfg(feature = "strict")]
385 return _serde::__private::Err(
386 <__A::Error as _serde::de::Error>::duplicate_field(
387 "variableBindingSet",
388 ),
389 );
390 }
391 m_variableBindingSet = _serde::__private::Some(
392 match __A::next_value::<Pointer>(&mut __map) {
393 _serde::__private::Ok(__val) => __val,
394 _serde::__private::Err(__err) => {
395 return _serde::__private::Err(__err);
396 }
397 },
398 );
399 }
400 __Field::m_userData => {
401 #[cfg(
402 any(feature = "strict", feature = "ignore_duplicates")
403 )]
404 if _serde::__private::Option::is_some(&m_userData) {
405 #[cfg(feature = "ignore_duplicates")]
406 {
407 __A::skip_value(&mut __map)?;
408 continue;
409 }
410 #[cfg(feature = "strict")]
411 return _serde::__private::Err(
412 <__A::Error as _serde::de::Error>::duplicate_field(
413 "userData",
414 ),
415 );
416 }
417 m_userData = _serde::__private::Some(
418 match __A::next_value::<Ulong>(&mut __map) {
419 _serde::__private::Ok(__val) => __val,
420 _serde::__private::Err(__err) => {
421 return _serde::__private::Err(__err);
422 }
423 },
424 );
425 }
426 __Field::m_name => {
427 #[cfg(
428 any(feature = "strict", feature = "ignore_duplicates")
429 )]
430 if _serde::__private::Option::is_some(&m_name) {
431 #[cfg(feature = "ignore_duplicates")]
432 {
433 __A::skip_value(&mut __map)?;
434 continue;
435 }
436 #[cfg(feature = "strict")]
437 return _serde::__private::Err(
438 <__A::Error as _serde::de::Error>::duplicate_field("name"),
439 );
440 }
441 m_name = _serde::__private::Some(
442 match __A::next_value::<StringPtr<'de>>(&mut __map) {
443 _serde::__private::Ok(__val) => __val,
444 _serde::__private::Err(__err) => {
445 return _serde::__private::Err(__err);
446 }
447 },
448 );
449 }
450 _ => __A::skip_value(&mut __map)?,
451 }
452 }
453 let m_variableBindingSet = match m_variableBindingSet {
454 _serde::__private::Some(__field) => __field,
455 _serde::__private::None => {
456 #[cfg(feature = "strict")]
457 return _serde::__private::Err(
458 <__A::Error as _serde::de::Error>::missing_field(
459 "variableBindingSet",
460 ),
461 );
462 #[cfg(not(feature = "strict"))] Default::default()
463 }
464 };
465 let m_userData = match m_userData {
466 _serde::__private::Some(__field) => __field,
467 _serde::__private::None => {
468 #[cfg(feature = "strict")]
469 return _serde::__private::Err(
470 <__A::Error as _serde::de::Error>::missing_field("userData"),
471 );
472 #[cfg(not(feature = "strict"))] Default::default()
473 }
474 };
475 let m_name = match m_name {
476 _serde::__private::Some(__field) => __field,
477 _serde::__private::None => {
478 #[cfg(feature = "strict")]
479 return _serde::__private::Err(
480 <__A::Error as _serde::de::Error>::missing_field("name"),
481 );
482 #[cfg(not(feature = "strict"))] Default::default()
483 }
484 };
485 let __ptr = None;
486 let parent = hkBaseObject { __ptr };
487 let parent = hkReferencedObject {
488 __ptr,
489 parent,
490 ..Default::default()
491 };
492 let parent = hkbBindable {
493 __ptr,
494 parent,
495 m_variableBindingSet,
496 ..Default::default()
497 };
498 let __ptr = __A::class_ptr(&mut __map);
499 _serde::__private::Ok(hkbNode {
500 __ptr,
501 parent,
502 m_userData,
503 m_name,
504 ..Default::default()
505 })
506 }
507 }
508 const FIELDS: &[&str] = &["userData", "name", "id", "cloneState", "padNode"];
509 _serde::Deserializer::deserialize_struct(
510 deserializer,
511 "hkbNode",
512 FIELDS,
513 __hkbNodeVisitor {
514 marker: _serde::__private::PhantomData::<hkbNode>,
515 lifetime: _serde::__private::PhantomData,
516 },
517 )
518 }
519 }
520};