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