1#![warn(clippy::all)]
4#![allow(unused_parens, unused_mut, unused_imports, nonstandard_style)]
5
6use bitflags::bitflags;
7use fidl::encoding::{MessageBufFor, ProxyChannelBox, ResourceDialect};
8use futures::future::{self, MaybeDone, TryFutureExt};
9use zx_status;
10
11#[derive(Clone, Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
12pub struct Config {
13 pub attach_a11y_view: bool,
14 pub display_pixel_density: String,
15 pub display_rotation: u64,
16 pub enable_button_baton_passing: bool,
17 pub enable_mouse_baton_passing: bool,
18 pub enable_touch_baton_passing: bool,
19 pub idle_threshold_ms: u64,
20 pub supported_input_devices: Vec<String>,
21 pub suspend_enabled: bool,
22 pub viewing_distance: String,
23}
24
25impl fidl::Persistable for Config {}
26
27mod internal {
28 use super::*;
29
30 impl fidl::encoding::ValueTypeMarker for Config {
31 type Borrowed<'a> = &'a Self;
32 fn borrow(value: &<Self as fidl::encoding::TypeMarker>::Owned) -> Self::Borrowed<'_> {
33 value
34 }
35 }
36
37 unsafe impl fidl::encoding::TypeMarker for Config {
38 type Owned = Self;
39
40 #[inline(always)]
41 fn inline_align(_context: fidl::encoding::Context) -> usize {
42 8
43 }
44
45 #[inline(always)]
46 fn inline_size(_context: fidl::encoding::Context) -> usize {
47 88
48 }
49 }
50
51 unsafe impl<D: fidl::encoding::ResourceDialect> fidl::encoding::Encode<Config, D> for &Config {
52 #[inline]
53 unsafe fn encode(
54 self,
55 encoder: &mut fidl::encoding::Encoder<'_, D>,
56 offset: usize,
57 _depth: fidl::encoding::Depth,
58 ) -> fidl::Result<()> {
59 encoder.debug_check_bounds::<Config>(offset);
60 fidl::encoding::Encode::<Config, D>::encode(
62 (
63 <bool as fidl::encoding::ValueTypeMarker>::borrow(&self.attach_a11y_view),
64 <fidl::encoding::BoundedString<8> as fidl::encoding::ValueTypeMarker>::borrow(&self.display_pixel_density),
65 <u64 as fidl::encoding::ValueTypeMarker>::borrow(&self.display_rotation),
66 <bool as fidl::encoding::ValueTypeMarker>::borrow(&self.enable_button_baton_passing),
67 <bool as fidl::encoding::ValueTypeMarker>::borrow(&self.enable_mouse_baton_passing),
68 <bool as fidl::encoding::ValueTypeMarker>::borrow(&self.enable_touch_baton_passing),
69 <u64 as fidl::encoding::ValueTypeMarker>::borrow(&self.idle_threshold_ms),
70 <fidl::encoding::Vector<fidl::encoding::BoundedString<12>, 6> as fidl::encoding::ValueTypeMarker>::borrow(&self.supported_input_devices),
71 <bool as fidl::encoding::ValueTypeMarker>::borrow(&self.suspend_enabled),
72 <fidl::encoding::BoundedString<8> as fidl::encoding::ValueTypeMarker>::borrow(&self.viewing_distance),
73 ),
74 encoder, offset, _depth
75 )
76 }
77 }
78 unsafe impl<
79 D: fidl::encoding::ResourceDialect,
80 T0: fidl::encoding::Encode<bool, D>,
81 T1: fidl::encoding::Encode<fidl::encoding::BoundedString<8>, D>,
82 T2: fidl::encoding::Encode<u64, D>,
83 T3: fidl::encoding::Encode<bool, D>,
84 T4: fidl::encoding::Encode<bool, D>,
85 T5: fidl::encoding::Encode<bool, D>,
86 T6: fidl::encoding::Encode<u64, D>,
87 T7: fidl::encoding::Encode<fidl::encoding::Vector<fidl::encoding::BoundedString<12>, 6>, D>,
88 T8: fidl::encoding::Encode<bool, D>,
89 T9: fidl::encoding::Encode<fidl::encoding::BoundedString<8>, D>,
90 > fidl::encoding::Encode<Config, D> for (T0, T1, T2, T3, T4, T5, T6, T7, T8, T9)
91 {
92 #[inline]
93 unsafe fn encode(
94 self,
95 encoder: &mut fidl::encoding::Encoder<'_, D>,
96 offset: usize,
97 depth: fidl::encoding::Depth,
98 ) -> fidl::Result<()> {
99 encoder.debug_check_bounds::<Config>(offset);
100 unsafe {
103 let ptr = encoder.buf.as_mut_ptr().add(offset).offset(0);
104 (ptr as *mut u64).write_unaligned(0);
105 }
106 unsafe {
107 let ptr = encoder.buf.as_mut_ptr().add(offset).offset(32);
108 (ptr as *mut u64).write_unaligned(0);
109 }
110 unsafe {
111 let ptr = encoder.buf.as_mut_ptr().add(offset).offset(64);
112 (ptr as *mut u64).write_unaligned(0);
113 }
114 self.0.encode(encoder, offset + 0, depth)?;
116 self.1.encode(encoder, offset + 8, depth)?;
117 self.2.encode(encoder, offset + 24, depth)?;
118 self.3.encode(encoder, offset + 32, depth)?;
119 self.4.encode(encoder, offset + 33, depth)?;
120 self.5.encode(encoder, offset + 34, depth)?;
121 self.6.encode(encoder, offset + 40, depth)?;
122 self.7.encode(encoder, offset + 48, depth)?;
123 self.8.encode(encoder, offset + 64, depth)?;
124 self.9.encode(encoder, offset + 72, depth)?;
125 Ok(())
126 }
127 }
128
129 impl<D: fidl::encoding::ResourceDialect> fidl::encoding::Decode<Self, D> for Config {
130 #[inline(always)]
131 fn new_empty() -> Self {
132 Self {
133 attach_a11y_view: fidl::new_empty!(bool, D),
134 display_pixel_density: fidl::new_empty!(fidl::encoding::BoundedString<8>, D),
135 display_rotation: fidl::new_empty!(u64, D),
136 enable_button_baton_passing: fidl::new_empty!(bool, D),
137 enable_mouse_baton_passing: fidl::new_empty!(bool, D),
138 enable_touch_baton_passing: fidl::new_empty!(bool, D),
139 idle_threshold_ms: fidl::new_empty!(u64, D),
140 supported_input_devices: fidl::new_empty!(
141 fidl::encoding::Vector<fidl::encoding::BoundedString<12>, 6>,
142 D
143 ),
144 suspend_enabled: fidl::new_empty!(bool, D),
145 viewing_distance: fidl::new_empty!(fidl::encoding::BoundedString<8>, D),
146 }
147 }
148
149 #[inline]
150 unsafe fn decode(
151 &mut self,
152 decoder: &mut fidl::encoding::Decoder<'_, D>,
153 offset: usize,
154 _depth: fidl::encoding::Depth,
155 ) -> fidl::Result<()> {
156 decoder.debug_check_bounds::<Self>(offset);
157 let ptr = unsafe { decoder.buf.as_ptr().add(offset).offset(0) };
159 let padval = unsafe { (ptr as *const u64).read_unaligned() };
160 let mask = 0xffffffffffffff00u64;
161 let maskedval = padval & mask;
162 if maskedval != 0 {
163 return Err(fidl::Error::NonZeroPadding {
164 padding_start: offset + 0 + ((mask as u64).trailing_zeros() / 8) as usize,
165 });
166 }
167 let ptr = unsafe { decoder.buf.as_ptr().add(offset).offset(32) };
168 let padval = unsafe { (ptr as *const u64).read_unaligned() };
169 let mask = 0xffffffffff000000u64;
170 let maskedval = padval & mask;
171 if maskedval != 0 {
172 return Err(fidl::Error::NonZeroPadding {
173 padding_start: offset + 32 + ((mask as u64).trailing_zeros() / 8) as usize,
174 });
175 }
176 let ptr = unsafe { decoder.buf.as_ptr().add(offset).offset(64) };
177 let padval = unsafe { (ptr as *const u64).read_unaligned() };
178 let mask = 0xffffffffffffff00u64;
179 let maskedval = padval & mask;
180 if maskedval != 0 {
181 return Err(fidl::Error::NonZeroPadding {
182 padding_start: offset + 64 + ((mask as u64).trailing_zeros() / 8) as usize,
183 });
184 }
185 fidl::decode!(bool, D, &mut self.attach_a11y_view, decoder, offset + 0, _depth)?;
186 fidl::decode!(
187 fidl::encoding::BoundedString<8>,
188 D,
189 &mut self.display_pixel_density,
190 decoder,
191 offset + 8,
192 _depth
193 )?;
194 fidl::decode!(u64, D, &mut self.display_rotation, decoder, offset + 24, _depth)?;
195 fidl::decode!(
196 bool,
197 D,
198 &mut self.enable_button_baton_passing,
199 decoder,
200 offset + 32,
201 _depth
202 )?;
203 fidl::decode!(
204 bool,
205 D,
206 &mut self.enable_mouse_baton_passing,
207 decoder,
208 offset + 33,
209 _depth
210 )?;
211 fidl::decode!(
212 bool,
213 D,
214 &mut self.enable_touch_baton_passing,
215 decoder,
216 offset + 34,
217 _depth
218 )?;
219 fidl::decode!(u64, D, &mut self.idle_threshold_ms, decoder, offset + 40, _depth)?;
220 fidl::decode!(
221 fidl::encoding::Vector<fidl::encoding::BoundedString<12>, 6>,
222 D,
223 &mut self.supported_input_devices,
224 decoder,
225 offset + 48,
226 _depth
227 )?;
228 fidl::decode!(bool, D, &mut self.suspend_enabled, decoder, offset + 64, _depth)?;
229 fidl::decode!(
230 fidl::encoding::BoundedString<8>,
231 D,
232 &mut self.viewing_distance,
233 decoder,
234 offset + 72,
235 _depth
236 )?;
237 Ok(())
238 }
239 }
240}