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