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