Skip to main content

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