fidl_cf_sc_internal_pkgcacheconfig__common/
fidl_cf_sc_internal_pkgcacheconfig__common.rs1#![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 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 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 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 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}