fidl_cf_sc_internal_pkgcacheconfig__common/
fidl_cf_sc_internal_pkgcacheconfig__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 all_packages_executable: bool,
14    pub enable_upgradable_packages: bool,
15    pub system_image_hash: String,
16    pub use_system_image: bool,
17}
18
19impl fidl::Persistable for Config {}
20
21mod internal {
22    use super::*;
23
24    impl fidl::encoding::ValueTypeMarker for Config {
25        type Borrowed<'a> = &'a Self;
26        fn borrow(value: &<Self as fidl::encoding::TypeMarker>::Owned) -> Self::Borrowed<'_> {
27            value
28        }
29    }
30
31    unsafe impl fidl::encoding::TypeMarker for Config {
32        type Owned = Self;
33
34        #[inline(always)]
35        fn inline_align(_context: fidl::encoding::Context) -> usize {
36            8
37        }
38
39        #[inline(always)]
40        fn inline_size(_context: fidl::encoding::Context) -> usize {
41            32
42        }
43    }
44
45    unsafe impl<D: fidl::encoding::ResourceDialect> fidl::encoding::Encode<Config, D> for &Config {
46        #[inline]
47        unsafe fn encode(
48            self,
49            encoder: &mut fidl::encoding::Encoder<'_, D>,
50            offset: usize,
51            _depth: fidl::encoding::Depth,
52        ) -> fidl::Result<()> {
53            encoder.debug_check_bounds::<Config>(offset);
54            // Delegate to tuple encoding.
55            fidl::encoding::Encode::<Config, D>::encode(
56                (
57                    <bool as fidl::encoding::ValueTypeMarker>::borrow(
58                        &self.all_packages_executable,
59                    ),
60                    <bool as fidl::encoding::ValueTypeMarker>::borrow(
61                        &self.enable_upgradable_packages,
62                    ),
63                    <fidl::encoding::BoundedString<100> as fidl::encoding::ValueTypeMarker>::borrow(
64                        &self.system_image_hash,
65                    ),
66                    <bool as fidl::encoding::ValueTypeMarker>::borrow(&self.use_system_image),
67                ),
68                encoder,
69                offset,
70                _depth,
71            )
72        }
73    }
74    unsafe impl<
75        D: fidl::encoding::ResourceDialect,
76        T0: fidl::encoding::Encode<bool, D>,
77        T1: fidl::encoding::Encode<bool, D>,
78        T2: fidl::encoding::Encode<fidl::encoding::BoundedString<100>, D>,
79        T3: fidl::encoding::Encode<bool, D>,
80    > fidl::encoding::Encode<Config, D> for (T0, T1, T2, T3)
81    {
82        #[inline]
83        unsafe fn encode(
84            self,
85            encoder: &mut fidl::encoding::Encoder<'_, D>,
86            offset: usize,
87            depth: fidl::encoding::Depth,
88        ) -> fidl::Result<()> {
89            encoder.debug_check_bounds::<Config>(offset);
90            // Zero out padding regions. There's no need to apply masks
91            // because the unmasked parts will be overwritten by fields.
92            unsafe {
93                let ptr = encoder.buf.as_mut_ptr().add(offset).offset(0);
94                (ptr as *mut u64).write_unaligned(0);
95            }
96            unsafe {
97                let ptr = encoder.buf.as_mut_ptr().add(offset).offset(24);
98                (ptr as *mut u64).write_unaligned(0);
99            }
100            // Write the fields.
101            self.0.encode(encoder, offset + 0, depth)?;
102            self.1.encode(encoder, offset + 1, depth)?;
103            self.2.encode(encoder, offset + 8, depth)?;
104            self.3.encode(encoder, offset + 24, depth)?;
105            Ok(())
106        }
107    }
108
109    impl<D: fidl::encoding::ResourceDialect> fidl::encoding::Decode<Self, D> for Config {
110        #[inline(always)]
111        fn new_empty() -> Self {
112            Self {
113                all_packages_executable: fidl::new_empty!(bool, D),
114                enable_upgradable_packages: fidl::new_empty!(bool, D),
115                system_image_hash: fidl::new_empty!(fidl::encoding::BoundedString<100>, D),
116                use_system_image: fidl::new_empty!(bool, D),
117            }
118        }
119
120        #[inline]
121        unsafe fn decode(
122            &mut self,
123            decoder: &mut fidl::encoding::Decoder<'_, D>,
124            offset: usize,
125            _depth: fidl::encoding::Depth,
126        ) -> fidl::Result<()> {
127            decoder.debug_check_bounds::<Self>(offset);
128            // Verify that padding bytes are zero.
129            let ptr = unsafe { decoder.buf.as_ptr().add(offset).offset(0) };
130            let padval = unsafe { (ptr as *const u64).read_unaligned() };
131            let mask = 0xffffffffffff0000u64;
132            let maskedval = padval & mask;
133            if maskedval != 0 {
134                return Err(fidl::Error::NonZeroPadding {
135                    padding_start: offset + 0 + ((mask as u64).trailing_zeros() / 8) as usize,
136                });
137            }
138            let ptr = unsafe { decoder.buf.as_ptr().add(offset).offset(24) };
139            let padval = unsafe { (ptr as *const u64).read_unaligned() };
140            let mask = 0xffffffffffffff00u64;
141            let maskedval = padval & mask;
142            if maskedval != 0 {
143                return Err(fidl::Error::NonZeroPadding {
144                    padding_start: offset + 24 + ((mask as u64).trailing_zeros() / 8) as usize,
145                });
146            }
147            fidl::decode!(bool, D, &mut self.all_packages_executable, decoder, offset + 0, _depth)?;
148            fidl::decode!(
149                bool,
150                D,
151                &mut self.enable_upgradable_packages,
152                decoder,
153                offset + 1,
154                _depth
155            )?;
156            fidl::decode!(
157                fidl::encoding::BoundedString<100>,
158                D,
159                &mut self.system_image_hash,
160                decoder,
161                offset + 8,
162                _depth
163            )?;
164            fidl::decode!(bool, D, &mut self.use_system_image, decoder, offset + 24, _depth)?;
165            Ok(())
166        }
167    }
168}