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