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