Skip to main content

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_merge_touch_events: bool,
17    pub idle_threshold_ms: u64,
18    pub supported_input_devices: Vec<String>,
19    pub suspend_enabled: bool,
20    pub viewing_distance: String,
21}
22
23impl fidl::Persistable for Config {}
24
25mod internal {
26    use super::*;
27
28    impl fidl::encoding::ValueTypeMarker for Config {
29        type Borrowed<'a> = &'a Self;
30        fn borrow(value: &<Self as fidl::encoding::TypeMarker>::Owned) -> Self::Borrowed<'_> {
31            value
32        }
33    }
34
35    unsafe impl fidl::encoding::TypeMarker for Config {
36        type Owned = Self;
37
38        #[inline(always)]
39        fn inline_align(_context: fidl::encoding::Context) -> usize {
40            8
41        }
42
43        #[inline(always)]
44        fn inline_size(_context: fidl::encoding::Context) -> usize {
45            88
46        }
47    }
48
49    unsafe impl<D: fidl::encoding::ResourceDialect> fidl::encoding::Encode<Config, D> for &Config {
50        #[inline]
51        unsafe fn encode(
52            self,
53            encoder: &mut fidl::encoding::Encoder<'_, D>,
54            offset: usize,
55            _depth: fidl::encoding::Depth,
56        ) -> fidl::Result<()> {
57            encoder.debug_check_bounds::<Config>(offset);
58            // Delegate to tuple encoding.
59            fidl::encoding::Encode::<Config, D>::encode(
60                (
61                    <bool as fidl::encoding::ValueTypeMarker>::borrow(&self.attach_a11y_view),
62                    <fidl::encoding::BoundedString<8> as fidl::encoding::ValueTypeMarker>::borrow(&self.display_pixel_density),
63                    <u64 as fidl::encoding::ValueTypeMarker>::borrow(&self.display_rotation),
64                    <bool as fidl::encoding::ValueTypeMarker>::borrow(&self.enable_merge_touch_events),
65                    <u64 as fidl::encoding::ValueTypeMarker>::borrow(&self.idle_threshold_ms),
66                    <fidl::encoding::Vector<fidl::encoding::BoundedString<12>, 6> as fidl::encoding::ValueTypeMarker>::borrow(&self.supported_input_devices),
67                    <bool as fidl::encoding::ValueTypeMarker>::borrow(&self.suspend_enabled),
68                    <fidl::encoding::BoundedString<8> as fidl::encoding::ValueTypeMarker>::borrow(&self.viewing_distance),
69                ),
70                encoder, offset, _depth
71            )
72        }
73    }
74    unsafe impl<
75        D: fidl::encoding::ResourceDialect,
76        T0: fidl::encoding::Encode<bool, D>,
77        T1: fidl::encoding::Encode<fidl::encoding::BoundedString<8>, D>,
78        T2: fidl::encoding::Encode<u64, D>,
79        T3: fidl::encoding::Encode<bool, D>,
80        T4: fidl::encoding::Encode<u64, D>,
81        T5: fidl::encoding::Encode<fidl::encoding::Vector<fidl::encoding::BoundedString<12>, 6>, D>,
82        T6: fidl::encoding::Encode<bool, D>,
83        T7: fidl::encoding::Encode<fidl::encoding::BoundedString<8>, D>,
84    > fidl::encoding::Encode<Config, D> for (T0, T1, T2, T3, T4, T5, T6, T7)
85    {
86        #[inline]
87        unsafe fn encode(
88            self,
89            encoder: &mut fidl::encoding::Encoder<'_, D>,
90            offset: usize,
91            depth: fidl::encoding::Depth,
92        ) -> fidl::Result<()> {
93            encoder.debug_check_bounds::<Config>(offset);
94            // Zero out padding regions. There's no need to apply masks
95            // because the unmasked parts will be overwritten by fields.
96            unsafe {
97                let ptr = encoder.buf.as_mut_ptr().add(offset).offset(0);
98                (ptr as *mut u64).write_unaligned(0);
99            }
100            unsafe {
101                let ptr = encoder.buf.as_mut_ptr().add(offset).offset(32);
102                (ptr as *mut u64).write_unaligned(0);
103            }
104            unsafe {
105                let ptr = encoder.buf.as_mut_ptr().add(offset).offset(64);
106                (ptr as *mut u64).write_unaligned(0);
107            }
108            // Write the fields.
109            self.0.encode(encoder, offset + 0, depth)?;
110            self.1.encode(encoder, offset + 8, depth)?;
111            self.2.encode(encoder, offset + 24, depth)?;
112            self.3.encode(encoder, offset + 32, depth)?;
113            self.4.encode(encoder, offset + 40, depth)?;
114            self.5.encode(encoder, offset + 48, depth)?;
115            self.6.encode(encoder, offset + 64, depth)?;
116            self.7.encode(encoder, offset + 72, depth)?;
117            Ok(())
118        }
119    }
120
121    impl<D: fidl::encoding::ResourceDialect> fidl::encoding::Decode<Self, D> for Config {
122        #[inline(always)]
123        fn new_empty() -> Self {
124            Self {
125                attach_a11y_view: fidl::new_empty!(bool, D),
126                display_pixel_density: fidl::new_empty!(fidl::encoding::BoundedString<8>, D),
127                display_rotation: fidl::new_empty!(u64, D),
128                enable_merge_touch_events: fidl::new_empty!(bool, D),
129                idle_threshold_ms: fidl::new_empty!(u64, D),
130                supported_input_devices: fidl::new_empty!(
131                    fidl::encoding::Vector<fidl::encoding::BoundedString<12>, 6>,
132                    D
133                ),
134                suspend_enabled: fidl::new_empty!(bool, D),
135                viewing_distance: fidl::new_empty!(fidl::encoding::BoundedString<8>, D),
136            }
137        }
138
139        #[inline]
140        unsafe fn decode(
141            &mut self,
142            decoder: &mut fidl::encoding::Decoder<'_, D>,
143            offset: usize,
144            _depth: fidl::encoding::Depth,
145        ) -> fidl::Result<()> {
146            decoder.debug_check_bounds::<Self>(offset);
147            // Verify that padding bytes are zero.
148            let ptr = unsafe { decoder.buf.as_ptr().add(offset).offset(0) };
149            let padval = unsafe { (ptr as *const u64).read_unaligned() };
150            let mask = 0xffffffffffffff00u64;
151            let maskedval = padval & mask;
152            if maskedval != 0 {
153                return Err(fidl::Error::NonZeroPadding {
154                    padding_start: offset + 0 + ((mask as u64).trailing_zeros() / 8) as usize,
155                });
156            }
157            let ptr = unsafe { decoder.buf.as_ptr().add(offset).offset(32) };
158            let padval = unsafe { (ptr as *const u64).read_unaligned() };
159            let mask = 0xffffffffffffff00u64;
160            let maskedval = padval & mask;
161            if maskedval != 0 {
162                return Err(fidl::Error::NonZeroPadding {
163                    padding_start: offset + 32 + ((mask as u64).trailing_zeros() / 8) as usize,
164                });
165            }
166            let ptr = unsafe { decoder.buf.as_ptr().add(offset).offset(64) };
167            let padval = unsafe { (ptr as *const u64).read_unaligned() };
168            let mask = 0xffffffffffffff00u64;
169            let maskedval = padval & mask;
170            if maskedval != 0 {
171                return Err(fidl::Error::NonZeroPadding {
172                    padding_start: offset + 64 + ((mask as u64).trailing_zeros() / 8) as usize,
173                });
174            }
175            fidl::decode!(bool, D, &mut self.attach_a11y_view, decoder, offset + 0, _depth)?;
176            fidl::decode!(
177                fidl::encoding::BoundedString<8>,
178                D,
179                &mut self.display_pixel_density,
180                decoder,
181                offset + 8,
182                _depth
183            )?;
184            fidl::decode!(u64, D, &mut self.display_rotation, decoder, offset + 24, _depth)?;
185            fidl::decode!(
186                bool,
187                D,
188                &mut self.enable_merge_touch_events,
189                decoder,
190                offset + 32,
191                _depth
192            )?;
193            fidl::decode!(u64, D, &mut self.idle_threshold_ms, decoder, offset + 40, _depth)?;
194            fidl::decode!(
195                fidl::encoding::Vector<fidl::encoding::BoundedString<12>, 6>,
196                D,
197                &mut self.supported_input_devices,
198                decoder,
199                offset + 48,
200                _depth
201            )?;
202            fidl::decode!(bool, D, &mut self.suspend_enabled, decoder, offset + 64, _depth)?;
203            fidl::decode!(
204                fidl::encoding::BoundedString<8>,
205                D,
206                &mut self.viewing_distance,
207                decoder,
208                offset + 72,
209                _depth
210            )?;
211            Ok(())
212        }
213    }
214}