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