fidl_cf_sc_internal_scenemanagerstructuredconfig__common/
fidl_cf_sc_internal_scenemanagerstructuredconfig__common.rs

1// WARNING: This file is machine generated by fidlgen.
2
3#![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            // Delegate to tuple encoding.
61            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            // Zero out padding regions. There's no need to apply masks
101            // because the unmasked parts will be overwritten by fields.
102            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            // Write the fields.
115            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            // Verify that padding bytes are zero.
158            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}