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