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