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 hkbEventInfo {
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 = "flags"))]
31 #[cfg_attr(feature = "serde", serde(rename = "flags"))]
32 pub m_flags: Flags,
33}
34const _: () = {
35 use havok_serde as _serde;
36 impl _serde::HavokClass for hkbEventInfo {
37 #[inline]
38 fn name(&self) -> &'static str {
39 "hkbEventInfo"
40 }
41 #[inline]
42 fn signature(&self) -> _serde::__private::Signature {
43 _serde::__private::Signature::new(0x5874eed4)
44 }
45 #[allow(clippy::let_and_return, clippy::vec_init_then_push)]
46 fn deps_indexes(&self) -> Vec<usize> {
47 let mut v = Vec::new();
48 v
49 }
50 }
51 impl _serde::Serialize for hkbEventInfo {
52 fn serialize<S>(&self, __serializer: S) -> Result<S::Ok, S::Error>
53 where
54 S: _serde::ser::Serializer,
55 {
56 let class_meta = self
57 .__ptr
58 .map(|name| (name, _serde::__private::Signature::new(0x5874eed4)));
59 let mut serializer = __serializer
60 .serialize_struct("hkbEventInfo", class_meta, (4u64, 4u64))?;
61 serializer.serialize_field("flags", &self.m_flags)?;
62 serializer.end()
63 }
64 }
65};
66#[doc(hidden)]
67#[allow(non_upper_case_globals, unused_attributes, unused_qualifications)]
68const _: () = {
69 use havok_serde as _serde;
70 #[automatically_derived]
71 impl<'de> _serde::Deserialize<'de> for hkbEventInfo {
72 fn deserialize<__D>(deserializer: __D) -> core::result::Result<Self, __D::Error>
73 where
74 __D: _serde::Deserializer<'de>,
75 {
76 #[allow(non_camel_case_types)]
77 enum __Field {
78 m_flags,
79 __ignore,
80 }
81 struct __FieldVisitor;
82 impl<'de> _serde::de::Visitor<'de> for __FieldVisitor {
83 type Value = __Field;
84 fn expecting(
85 &self,
86 __formatter: &mut core::fmt::Formatter,
87 ) -> core::fmt::Result {
88 core::fmt::Formatter::write_str(__formatter, "field identifier")
89 }
90 #[allow(clippy::match_single_binding)]
92 #[allow(clippy::reversed_empty_ranges)]
93 #[allow(clippy::single_match)]
94 fn visit_key<__E>(
95 self,
96 __value: &str,
97 ) -> core::result::Result<Self::Value, __E>
98 where
99 __E: _serde::de::Error,
100 {
101 match __value {
102 "flags" => Ok(__Field::m_flags),
103 _ => Ok(__Field::__ignore),
104 }
105 }
106 }
107 impl<'de> _serde::Deserialize<'de> for __Field {
108 #[inline]
109 fn deserialize<__D>(
110 __deserializer: __D,
111 ) -> core::result::Result<Self, __D::Error>
112 where
113 __D: _serde::Deserializer<'de>,
114 {
115 _serde::Deserializer::deserialize_key(__deserializer, __FieldVisitor)
116 }
117 }
118 struct __hkbEventInfoVisitor<'de> {
119 marker: _serde::__private::PhantomData<hkbEventInfo>,
120 lifetime: _serde::__private::PhantomData<&'de ()>,
121 }
122 #[allow(clippy::match_single_binding)]
123 #[allow(clippy::reversed_empty_ranges)]
124 #[allow(clippy::single_match)]
125 impl<'de> _serde::de::Visitor<'de> for __hkbEventInfoVisitor<'de> {
126 type Value = hkbEventInfo;
127 fn expecting(
128 &self,
129 __formatter: &mut core::fmt::Formatter,
130 ) -> core::fmt::Result {
131 core::fmt::Formatter::write_str(__formatter, "struct hkbEventInfo")
132 }
133 fn visit_struct_for_bytes<__A>(
134 self,
135 mut __map: __A,
136 ) -> _serde::__private::Result<Self::Value, __A::Error>
137 where
138 __A: _serde::de::MapAccess<'de>,
139 {
140 let __ptr = __A::class_ptr(&mut __map);
141 let mut m_flags: _serde::__private::Option<Flags> = _serde::__private::None;
142 for i in 0..1usize {
143 match i {
144 0usize => {
145 if _serde::__private::Option::is_some(&m_flags) {
146 return _serde::__private::Err(
147 <__A::Error as _serde::de::Error>::duplicate_field("flags"),
148 );
149 }
150 m_flags = _serde::__private::Some(
151 match __A::next_value::<Flags>(&mut __map) {
152 _serde::__private::Ok(__val) => __val,
153 _serde::__private::Err(__err) => {
154 return _serde::__private::Err(__err);
155 }
156 },
157 );
158 }
159 _ => {}
160 }
161 }
162 let m_flags = match m_flags {
163 _serde::__private::Some(__field) => __field,
164 _serde::__private::None => {
165 return _serde::__private::Err(
166 <__A::Error as _serde::de::Error>::missing_field("flags"),
167 );
168 }
169 };
170 _serde::__private::Ok(hkbEventInfo { __ptr, m_flags })
171 }
172 #[allow(clippy::manual_unwrap_or_default)]
173 fn visit_struct<__A>(
174 self,
175 mut __map: __A,
176 ) -> _serde::__private::Result<Self::Value, __A::Error>
177 where
178 __A: _serde::de::MapAccess<'de>,
179 {
180 let mut m_flags: _serde::__private::Option<Flags> = _serde::__private::None;
181 while let _serde::__private::Some(__key) = {
182 __A::next_key::<__Field>(&mut __map)?
183 } {
184 match __key {
185 __Field::m_flags => {
186 #[cfg(
187 any(feature = "strict", feature = "ignore_duplicates")
188 )]
189 if _serde::__private::Option::is_some(&m_flags) {
190 #[cfg(feature = "ignore_duplicates")]
191 {
192 __A::skip_value(&mut __map)?;
193 continue;
194 }
195 #[cfg(feature = "strict")]
196 return _serde::__private::Err(
197 <__A::Error as _serde::de::Error>::duplicate_field("flags"),
198 );
199 }
200 m_flags = _serde::__private::Some(
201 match __A::next_value::<Flags>(&mut __map) {
202 _serde::__private::Ok(__val) => __val,
203 _serde::__private::Err(__err) => {
204 return _serde::__private::Err(__err);
205 }
206 },
207 );
208 }
209 _ => __A::skip_value(&mut __map)?,
210 }
211 }
212 let m_flags = match m_flags {
213 _serde::__private::Some(__field) => __field,
214 _serde::__private::None => {
215 #[cfg(feature = "strict")]
216 return _serde::__private::Err(
217 <__A::Error as _serde::de::Error>::missing_field("flags"),
218 );
219 #[cfg(not(feature = "strict"))] Default::default()
220 }
221 };
222 let __ptr = __A::class_ptr(&mut __map);
223 _serde::__private::Ok(hkbEventInfo { __ptr, m_flags })
224 }
225 }
226 const FIELDS: &[&str] = &["flags"];
227 _serde::Deserializer::deserialize_struct(
228 deserializer,
229 "hkbEventInfo",
230 FIELDS,
231 __hkbEventInfoVisitor {
232 marker: _serde::__private::PhantomData::<hkbEventInfo>,
233 lifetime: _serde::__private::PhantomData,
234 },
235 )
236 }
237 }
238};
239#[havok_types_derive::impl_flags_methods]
240bitflags::bitflags! {
241 #[doc = r" Bit flags"] #[doc = r""] #[doc = r" # C++ Info"] #[doc =
242 " - name: `Flags`(ctype: `hkFlags<Flags, hkUint32>`)"]
243 #[allow(non_upper_case_globals, non_snake_case)] #[cfg_attr(feature = "serde",
244 derive(serde_with::SerializeDisplay, serde_with::DeserializeFromStr))]
245 #[repr(transparent)] #[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)] pub struct
246 Flags : u32 { #[doc = "1"] const FLAG_SILENT = 1u32; #[doc = "2"] const
247 FLAG_SYNC_POINT = 2u32; }
248}
249#[cfg(feature = "json_schema")]
250const _: () = {
251 use schemars::{SchemaGenerator, Schema, JsonSchema, json_schema};
252 use std::borrow::Cow;
253 impl JsonSchema for Flags {
254 fn schema_name() -> Cow<'static, str> {
255 "Flags".into()
256 }
257 fn schema_id() -> Cow<'static, str> {
258 concat!(module_path!(), "::", "Flags").into()
259 }
260 fn json_schema(_generate: &mut SchemaGenerator) -> Schema {
261 json_schema!(
262 { "description" :
263 "Bitflags field. Specific flags: FLAG_SILENT: 1, FLAG_SYNC_POINT: 2. Additional unspecified bits may be set.(e.g.: BIT_FLAG|BIT_FLAG2|4)",
264 "type" : "string", }
265 )
266 }
267 }
268};
269const _: () = {
270 use havok_serde as __serde;
271 impl __serde::Serialize for Flags {
272 fn serialize<S>(&self, __serializer: S) -> Result<S::Ok, S::Error>
273 where
274 S: __serde::ser::Serializer,
275 {
276 let mut __serializer = __serializer.serialize_enum_flags()?;
277 if self.is_empty() {
278 __serializer.serialize_bits(&self.bits())?;
279 __serializer.serialize_empty_bit()?;
280 return __serializer.end();
281 }
282 for flag in self.iter() {
283 match flag {
284 Self::FLAG_SILENT => {
285 __serializer.serialize_field("FLAG_SILENT", &Self::FLAG_SILENT)
286 }
287 Self::FLAG_SYNC_POINT => {
288 __serializer
289 .serialize_field("FLAG_SYNC_POINT", &Self::FLAG_SYNC_POINT)
290 }
291 remain => {
292 __serializer
293 .serialize_field(&remain.bits().to_string(), &remain.bits())
294 }
295 }?;
296 }
297 __serializer.serialize_bits(&self.bits())?;
298 __serializer.end()
299 }
300 }
301};
302#[doc(hidden)]
303#[allow(non_upper_case_globals, unused_attributes, unused_qualifications)]
304const _: () = {
305 #[allow(unused_extern_crates, clippy::useless_attribute)]
306 extern crate havok_serde as _serde;
307 #[automatically_derived]
308 impl<'de> _serde::Deserialize<'de> for Flags {
309 fn deserialize<__D>(
310 __deserializer: __D,
311 ) -> _serde::__private::Result<Self, __D::Error>
312 where
313 __D: _serde::Deserializer<'de>,
314 {
315 #[doc(hidden)]
316 struct __Visitor<'de> {
317 marker: _serde::__private::PhantomData<Flags>,
318 lifetime: _serde::__private::PhantomData<&'de ()>,
319 }
320 impl<'de> _serde::de::Visitor<'de> for __Visitor<'de> {
321 type Value = Flags;
322 fn expecting(
323 &self,
324 __formatter: &mut _serde::__private::Formatter,
325 ) -> _serde::__private::fmt::Result {
326 _serde::__private::Formatter::write_str(
327 __formatter,
328 "struct Flags(flags)",
329 )
330 }
331 #[inline]
332 fn visit_uint32<__E>(
333 self,
334 __value: u32,
335 ) -> _serde::__private::Result<Self::Value, __E>
336 where
337 __E: _serde::de::Error,
338 {
339 Ok(Flags::from_bits_retain(__value as _))
340 }
341 fn visit_stringptr<__E>(
342 self,
343 __value: StringPtr<'de>,
344 ) -> _serde::__private::Result<Self::Value, __E>
345 where
346 __E: _serde::de::Error,
347 {
348 match <Flags as core::str::FromStr>::from_str(
349 __value.into_inner().unwrap().as_ref(),
350 ) {
351 Ok(flags) => Ok(flags),
352 Err(err) => Err(_serde::de::Error::custom(err)),
353 }
354 }
355 }
356 _serde::Deserializer::deserialize_flags(
357 __deserializer,
358 _serde::de::ReadEnumSize::Uint32,
359 __Visitor {
360 marker: _serde::__private::PhantomData::<Flags>,
361 lifetime: _serde::__private::PhantomData,
362 },
363 )
364 }
365 }
366};