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 hkLinkAttribute {
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 = "type"))]
31 #[cfg_attr(feature = "serde", serde(rename = "type"))]
32 pub m_type: Link,
33}
34const _: () = {
35 use havok_serde as _serde;
36 impl _serde::HavokClass for hkLinkAttribute {
37 #[inline]
38 fn name(&self) -> &'static str {
39 "hkLinkAttribute"
40 }
41 #[inline]
42 fn signature(&self) -> _serde::__private::Signature {
43 _serde::__private::Signature::new(0x255d8164)
44 }
45 #[allow(clippy::let_and_return, clippy::vec_init_then_push)]
46 fn deps_indexes(&self) -> Vec<usize> {
47 let mut v = Vec::new();
48 v
49 }
50 }
51 impl _serde::Serialize for hkLinkAttribute {
52 fn serialize<S>(&self, __serializer: S) -> Result<S::Ok, S::Error>
53 where
54 S: _serde::ser::Serializer,
55 {
56 let class_meta = self
57 .__ptr
58 .map(|name| (name, _serde::__private::Signature::new(0x255d8164)));
59 let mut serializer = __serializer
60 .serialize_struct("hkLinkAttribute", class_meta, (1u64, 1u64))?;
61 serializer.serialize_field("type", &self.m_type)?;
62 serializer.end()
63 }
64 }
65};
66#[doc(hidden)]
67#[allow(non_upper_case_globals, unused_attributes, unused_qualifications)]
68const _: () = {
69 use havok_serde as _serde;
70 #[automatically_derived]
71 impl<'de> _serde::Deserialize<'de> for hkLinkAttribute {
72 fn deserialize<__D>(deserializer: __D) -> core::result::Result<Self, __D::Error>
73 where
74 __D: _serde::Deserializer<'de>,
75 {
76 #[allow(non_camel_case_types)]
77 enum __Field {
78 m_type,
79 __ignore,
80 }
81 struct __FieldVisitor;
82 impl<'de> _serde::de::Visitor<'de> for __FieldVisitor {
83 type Value = __Field;
84 fn expecting(
85 &self,
86 __formatter: &mut core::fmt::Formatter,
87 ) -> core::fmt::Result {
88 core::fmt::Formatter::write_str(__formatter, "field identifier")
89 }
90 #[allow(clippy::match_single_binding)]
92 #[allow(clippy::reversed_empty_ranges)]
93 #[allow(clippy::single_match)]
94 fn visit_key<__E>(
95 self,
96 __value: &str,
97 ) -> core::result::Result<Self::Value, __E>
98 where
99 __E: _serde::de::Error,
100 {
101 match __value {
102 "type" => Ok(__Field::m_type),
103 _ => Ok(__Field::__ignore),
104 }
105 }
106 }
107 impl<'de> _serde::Deserialize<'de> for __Field {
108 #[inline]
109 fn deserialize<__D>(
110 __deserializer: __D,
111 ) -> core::result::Result<Self, __D::Error>
112 where
113 __D: _serde::Deserializer<'de>,
114 {
115 _serde::Deserializer::deserialize_key(__deserializer, __FieldVisitor)
116 }
117 }
118 struct __hkLinkAttributeVisitor<'de> {
119 marker: _serde::__private::PhantomData<hkLinkAttribute>,
120 lifetime: _serde::__private::PhantomData<&'de ()>,
121 }
122 #[allow(clippy::match_single_binding)]
123 #[allow(clippy::reversed_empty_ranges)]
124 #[allow(clippy::single_match)]
125 impl<'de> _serde::de::Visitor<'de> for __hkLinkAttributeVisitor<'de> {
126 type Value = hkLinkAttribute;
127 fn expecting(
128 &self,
129 __formatter: &mut core::fmt::Formatter,
130 ) -> core::fmt::Result {
131 core::fmt::Formatter::write_str(
132 __formatter,
133 "struct hkLinkAttribute",
134 )
135 }
136 fn visit_struct_for_bytes<__A>(
137 self,
138 mut __map: __A,
139 ) -> _serde::__private::Result<Self::Value, __A::Error>
140 where
141 __A: _serde::de::MapAccess<'de>,
142 {
143 let __ptr = __A::class_ptr(&mut __map);
144 let mut m_type: _serde::__private::Option<Link> = _serde::__private::None;
145 for i in 0..1usize {
146 match i {
147 0usize => {
148 if _serde::__private::Option::is_some(&m_type) {
149 return _serde::__private::Err(
150 <__A::Error as _serde::de::Error>::duplicate_field("type"),
151 );
152 }
153 m_type = _serde::__private::Some(
154 match __A::next_value::<Link>(&mut __map) {
155 _serde::__private::Ok(__val) => __val,
156 _serde::__private::Err(__err) => {
157 return _serde::__private::Err(__err);
158 }
159 },
160 );
161 }
162 _ => {}
163 }
164 }
165 let m_type = match m_type {
166 _serde::__private::Some(__field) => __field,
167 _serde::__private::None => {
168 return _serde::__private::Err(
169 <__A::Error as _serde::de::Error>::missing_field("type"),
170 );
171 }
172 };
173 _serde::__private::Ok(hkLinkAttribute { __ptr, m_type })
174 }
175 #[allow(clippy::manual_unwrap_or_default)]
176 fn visit_struct<__A>(
177 self,
178 mut __map: __A,
179 ) -> _serde::__private::Result<Self::Value, __A::Error>
180 where
181 __A: _serde::de::MapAccess<'de>,
182 {
183 let mut m_type: _serde::__private::Option<Link> = _serde::__private::None;
184 while let _serde::__private::Some(__key) = {
185 __A::next_key::<__Field>(&mut __map)?
186 } {
187 match __key {
188 __Field::m_type => {
189 #[cfg(
190 any(feature = "strict", feature = "ignore_duplicates")
191 )]
192 if _serde::__private::Option::is_some(&m_type) {
193 #[cfg(feature = "ignore_duplicates")]
194 {
195 __A::skip_value(&mut __map)?;
196 continue;
197 }
198 #[cfg(feature = "strict")]
199 return _serde::__private::Err(
200 <__A::Error as _serde::de::Error>::duplicate_field("type"),
201 );
202 }
203 m_type = _serde::__private::Some(
204 match __A::next_value::<Link>(&mut __map) {
205 _serde::__private::Ok(__val) => __val,
206 _serde::__private::Err(__err) => {
207 return _serde::__private::Err(__err);
208 }
209 },
210 );
211 }
212 _ => __A::skip_value(&mut __map)?,
213 }
214 }
215 let m_type = match m_type {
216 _serde::__private::Some(__field) => __field,
217 _serde::__private::None => {
218 #[cfg(feature = "strict")]
219 return _serde::__private::Err(
220 <__A::Error as _serde::de::Error>::missing_field("type"),
221 );
222 #[cfg(not(feature = "strict"))] Default::default()
223 }
224 };
225 let __ptr = __A::class_ptr(&mut __map);
226 _serde::__private::Ok(hkLinkAttribute { __ptr, m_type })
227 }
228 }
229 const FIELDS: &[&str] = &["type"];
230 _serde::Deserializer::deserialize_struct(
231 deserializer,
232 "hkLinkAttribute",
233 FIELDS,
234 __hkLinkAttributeVisitor {
235 marker: _serde::__private::PhantomData::<hkLinkAttribute>,
236 lifetime: _serde::__private::PhantomData,
237 },
238 )
239 }
240 }
241};
242#[allow(non_upper_case_globals, non_snake_case)]
245#[cfg_attr(feature = "json_schema", derive(schemars::JsonSchema))]
246#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
247#[derive(
248 Debug,
249 Clone,
250 Default,
251 PartialEq,
252 Eq,
253 PartialOrd,
254 Ord,
255 num_derive::ToPrimitive,
256 num_derive::FromPrimitive,
257)]
258pub enum Link {
259 #[default]
260 NONE = 0isize,
261 DIRECT_LINK = 1isize,
262 CHILD = 2isize,
263 MESH = 3isize,
264 PARENT_NAME = 4isize,
265}
266const _: () = {
267 use havok_serde as __serde;
268 impl __serde::Serialize for Link {
269 fn serialize<S>(&self, __serializer: S) -> Result<S::Ok, S::Error>
270 where
271 S: __serde::ser::Serializer,
272 {
273 let mut __serializer = __serializer.serialize_enum_flags()?;
274 match self {
275 Self::NONE => __serializer.serialize_field("NONE", &0u64),
276 Self::DIRECT_LINK => __serializer.serialize_field("DIRECT_LINK", &1u64),
277 Self::CHILD => __serializer.serialize_field("CHILD", &2u64),
278 Self::MESH => __serializer.serialize_field("MESH", &3u64),
279 Self::PARENT_NAME => __serializer.serialize_field("PARENT_NAME", &4u64),
280 }?;
281 use num_traits::ToPrimitive as _;
282 let num = self.to_i8().ok_or(S::Error::custom("Failed enum Link to_i8"))?;
283 __serializer.serialize_bits(&num)?;
284 __serializer.end()
285 }
286 }
287};
288#[doc(hidden)]
289#[allow(non_upper_case_globals, unused_attributes, unused_qualifications)]
290const _: () = {
291 #[allow(unused_extern_crates, clippy::useless_attribute)]
292 extern crate havok_serde as _serde;
293 #[automatically_derived]
294 impl<'de> _serde::Deserialize<'de> for Link {
295 fn deserialize<__D>(
296 __deserializer: __D,
297 ) -> _serde::__private::Result<Self, __D::Error>
298 where
299 __D: _serde::Deserializer<'de>,
300 {
301 #[allow(non_camel_case_types)]
302 #[doc(hidden)]
303 enum __Field {
304 __field0,
305 __field1,
306 __field2,
307 __field3,
308 __field4,
309 }
310 #[doc(hidden)]
311 struct __FieldVisitor;
312 impl<'de> _serde::de::Visitor<'de> for __FieldVisitor {
313 type Value = __Field;
314 fn expecting(
315 &self,
316 __formatter: &mut _serde::__private::Formatter,
317 ) -> _serde::__private::fmt::Result {
318 _serde::__private::Formatter::write_str(
319 __formatter,
320 "variant identifier",
321 )
322 }
323 fn visit_int8<__E>(
324 self,
325 __value: i8,
326 ) -> _serde::__private::Result<Self::Value, __E>
327 where
328 __E: _serde::de::Error,
329 {
330 match __value {
331 0i8 => _serde::__private::Ok(__Field::__field0),
332 1i8 => _serde::__private::Ok(__Field::__field1),
333 2i8 => _serde::__private::Ok(__Field::__field2),
334 3i8 => _serde::__private::Ok(__Field::__field3),
335 4i8 => _serde::__private::Ok(__Field::__field4),
336 _ => {
337 _serde::__private::Err(
338 _serde::de::Error::invalid_value(
339 _serde::de::Unexpected::Int8(__value),
340 &"value(i8) of variant is one of 0, 1, 2, 3, 4",
341 ),
342 )
343 }
344 }
345 }
346 fn visit_stringptr<__E>(
347 self,
348 __value: StringPtr<'de>,
349 ) -> _serde::__private::Result<Self::Value, __E>
350 where
351 __E: _serde::de::Error,
352 {
353 if let Some(__value) = __value.into_inner() {
354 match __value.as_ref() {
355 v if v == "0" || v.eq_ignore_ascii_case("NONE") => {
356 _serde::__private::Ok(__Field::__field0)
357 }
358 v if v == "1" || v.eq_ignore_ascii_case("DIRECT_LINK") => {
359 _serde::__private::Ok(__Field::__field1)
360 }
361 v if v == "2" || v.eq_ignore_ascii_case("CHILD") => {
362 _serde::__private::Ok(__Field::__field2)
363 }
364 v if v == "3" || v.eq_ignore_ascii_case("MESH") => {
365 _serde::__private::Ok(__Field::__field3)
366 }
367 v if v == "4" || v.eq_ignore_ascii_case("PARENT_NAME") => {
368 _serde::__private::Ok(__Field::__field4)
369 }
370 _ => {
371 _serde::__private::Err(
372 _serde::de::Error::unknown_variant(&__value, VARIANTS),
373 )
374 }
375 }
376 } else {
377 _serde::__private::Err(
378 _serde::de::Error::unknown_variant("None", VARIANTS),
379 )
380 }
381 }
382 }
383 impl<'de> _serde::Deserialize<'de> for __Field {
384 #[inline]
385 fn deserialize<__D>(
386 __deserializer: __D,
387 ) -> _serde::__private::Result<Self, __D::Error>
388 where
389 __D: _serde::Deserializer<'de>,
390 {
391 _serde::Deserializer::deserialize_identifier(
392 __deserializer,
393 _serde::de::ReadEnumSize::Int8,
394 __FieldVisitor,
395 )
396 }
397 }
398 #[doc(hidden)]
399 struct __Visitor<'de> {
400 marker: _serde::__private::PhantomData<Link>,
401 lifetime: _serde::__private::PhantomData<&'de ()>,
402 }
403 impl<'de> _serde::de::Visitor<'de> for __Visitor<'de> {
404 type Value = Link;
405 fn expecting(
406 &self,
407 __formatter: &mut _serde::__private::Formatter,
408 ) -> _serde::__private::fmt::Result {
409 _serde::__private::Formatter::write_str(__formatter, "enum Link")
410 }
411 fn visit_enum<__A>(
412 self,
413 __data: __A,
414 ) -> _serde::__private::Result<Self::Value, __A::Error>
415 where
416 __A: _serde::de::EnumAccess<'de>,
417 {
418 match _serde::de::EnumAccess::variant(__data)? {
419 (__Field::__field0, __variant) => {
420 _serde::de::VariantAccess::unit_variant(__variant)?;
421 _serde::__private::Ok(Link::NONE)
422 }
423 (__Field::__field1, __variant) => {
424 _serde::de::VariantAccess::unit_variant(__variant)?;
425 _serde::__private::Ok(Link::DIRECT_LINK)
426 }
427 (__Field::__field2, __variant) => {
428 _serde::de::VariantAccess::unit_variant(__variant)?;
429 _serde::__private::Ok(Link::CHILD)
430 }
431 (__Field::__field3, __variant) => {
432 _serde::de::VariantAccess::unit_variant(__variant)?;
433 _serde::__private::Ok(Link::MESH)
434 }
435 (__Field::__field4, __variant) => {
436 _serde::de::VariantAccess::unit_variant(__variant)?;
437 _serde::__private::Ok(Link::PARENT_NAME)
438 }
439 }
440 }
441 }
442 #[doc(hidden)]
443 const VARIANTS: &'static [&'static str] = &[
444 "NONE",
445 "DIRECT_LINK",
446 "CHILD",
447 "MESH",
448 "PARENT_NAME",
449 ];
450 _serde::Deserializer::deserialize_enum(
451 __deserializer,
452 "Link",
453 VARIANTS,
454 __Visitor {
455 marker: _serde::__private::PhantomData::<Link>,
456 lifetime: _serde::__private::PhantomData,
457 },
458 )
459 }
460 }
461};