|  | // WARNING: This file is machine generated by fidlgen. | 
|  |  | 
|  | // fidl_experiment = output_index_json | 
|  |  | 
|  | #![warn(clippy::all)] | 
|  | #![allow(unused_parens, unused_mut, unused_imports, nonstandard_style)] | 
|  |  | 
|  | use bitflags::bitflags; | 
|  | use fidl::encoding::{MessageBufFor, ProxyChannelBox, ResourceDialect}; | 
|  | use futures::future::{self, MaybeDone, TryFutureExt}; | 
|  | use zx_status; | 
|  |  | 
|  | #[derive(Clone, Debug, Eq, Hash, Ord, PartialEq, PartialOrd)] | 
|  | pub struct SuperFooRequest { | 
|  | pub s: String, | 
|  | } | 
|  |  | 
|  | impl fidl::Persistable for SuperFooRequest {} | 
|  |  | 
|  | #[derive(Clone, Copy, Debug, Eq, Hash, Ord, PartialEq, PartialOrd)] | 
|  | #[repr(C)] | 
|  | pub struct SuperFooResponse { | 
|  | pub y: i64, | 
|  | } | 
|  |  | 
|  | impl fidl::Persistable for SuperFooResponse {} | 
|  |  | 
|  | pub mod sub_ordinals { | 
|  | pub const FOO: u64 = 0x68a61c2a230db8b8; | 
|  | } | 
|  |  | 
|  | pub mod super__ordinals { | 
|  | pub const FOO: u64 = 0x68a61c2a230db8b8; | 
|  | } | 
|  |  | 
|  | mod internal { | 
|  | use super::*; | 
|  |  | 
|  | impl fidl::encoding::ValueTypeMarker for SuperFooRequest { | 
|  | type Borrowed<'a> = &'a Self; | 
|  | fn borrow(value: &<Self as fidl::encoding::TypeMarker>::Owned) -> Self::Borrowed<'_> { | 
|  | value | 
|  | } | 
|  | } | 
|  |  | 
|  | unsafe impl fidl::encoding::TypeMarker for SuperFooRequest { | 
|  | type Owned = Self; | 
|  |  | 
|  | #[inline(always)] | 
|  | fn inline_align(_context: fidl::encoding::Context) -> usize { | 
|  | 8 | 
|  | } | 
|  |  | 
|  | #[inline(always)] | 
|  | fn inline_size(_context: fidl::encoding::Context) -> usize { | 
|  | 16 | 
|  | } | 
|  | } | 
|  |  | 
|  | unsafe impl<D: fidl::encoding::ResourceDialect> fidl::encoding::Encode<SuperFooRequest, D> | 
|  | for &SuperFooRequest | 
|  | { | 
|  | #[inline] | 
|  | unsafe fn encode( | 
|  | self, | 
|  | encoder: &mut fidl::encoding::Encoder<'_, D>, | 
|  | offset: usize, | 
|  | _depth: fidl::encoding::Depth, | 
|  | ) -> fidl::Result<()> { | 
|  | encoder.debug_check_bounds::<SuperFooRequest>(offset); | 
|  | // Delegate to tuple encoding. | 
|  | fidl::encoding::Encode::<SuperFooRequest, D>::encode( | 
|  | (<fidl::encoding::UnboundedString as fidl::encoding::ValueTypeMarker>::borrow( | 
|  | &self.s, | 
|  | ),), | 
|  | encoder, | 
|  | offset, | 
|  | _depth, | 
|  | ) | 
|  | } | 
|  | } | 
|  | unsafe impl< | 
|  | D: fidl::encoding::ResourceDialect, | 
|  | T0: fidl::encoding::Encode<fidl::encoding::UnboundedString, D>, | 
|  | > fidl::encoding::Encode<SuperFooRequest, D> for (T0,) | 
|  | { | 
|  | #[inline] | 
|  | unsafe fn encode( | 
|  | self, | 
|  | encoder: &mut fidl::encoding::Encoder<'_, D>, | 
|  | offset: usize, | 
|  | depth: fidl::encoding::Depth, | 
|  | ) -> fidl::Result<()> { | 
|  | encoder.debug_check_bounds::<SuperFooRequest>(offset); | 
|  | // Zero out padding regions. There's no need to apply masks | 
|  | // because the unmasked parts will be overwritten by fields. | 
|  | // Write the fields. | 
|  | self.0.encode(encoder, offset + 0, depth)?; | 
|  | Ok(()) | 
|  | } | 
|  | } | 
|  |  | 
|  | impl<D: fidl::encoding::ResourceDialect> fidl::encoding::Decode<Self, D> for SuperFooRequest { | 
|  | #[inline(always)] | 
|  | fn new_empty() -> Self { | 
|  | Self { s: fidl::new_empty!(fidl::encoding::UnboundedString, D) } | 
|  | } | 
|  |  | 
|  | #[inline] | 
|  | unsafe fn decode( | 
|  | &mut self, | 
|  | decoder: &mut fidl::encoding::Decoder<'_, D>, | 
|  | offset: usize, | 
|  | _depth: fidl::encoding::Depth, | 
|  | ) -> fidl::Result<()> { | 
|  | decoder.debug_check_bounds::<Self>(offset); | 
|  | // Verify that padding bytes are zero. | 
|  | fidl::decode!( | 
|  | fidl::encoding::UnboundedString, | 
|  | D, | 
|  | &mut self.s, | 
|  | decoder, | 
|  | offset + 0, | 
|  | _depth | 
|  | )?; | 
|  | Ok(()) | 
|  | } | 
|  | } | 
|  |  | 
|  | impl fidl::encoding::ValueTypeMarker for SuperFooResponse { | 
|  | type Borrowed<'a> = &'a Self; | 
|  | fn borrow(value: &<Self as fidl::encoding::TypeMarker>::Owned) -> Self::Borrowed<'_> { | 
|  | value | 
|  | } | 
|  | } | 
|  |  | 
|  | unsafe impl fidl::encoding::TypeMarker for SuperFooResponse { | 
|  | type Owned = Self; | 
|  |  | 
|  | #[inline(always)] | 
|  | fn inline_align(_context: fidl::encoding::Context) -> usize { | 
|  | 8 | 
|  | } | 
|  |  | 
|  | #[inline(always)] | 
|  | fn inline_size(_context: fidl::encoding::Context) -> usize { | 
|  | 8 | 
|  | } | 
|  | #[inline(always)] | 
|  | fn encode_is_copy() -> bool { | 
|  | true | 
|  | } | 
|  |  | 
|  | #[inline(always)] | 
|  | fn decode_is_copy() -> bool { | 
|  | true | 
|  | } | 
|  | } | 
|  |  | 
|  | unsafe impl<D: fidl::encoding::ResourceDialect> fidl::encoding::Encode<SuperFooResponse, D> | 
|  | for &SuperFooResponse | 
|  | { | 
|  | #[inline] | 
|  | unsafe fn encode( | 
|  | self, | 
|  | encoder: &mut fidl::encoding::Encoder<'_, D>, | 
|  | offset: usize, | 
|  | _depth: fidl::encoding::Depth, | 
|  | ) -> fidl::Result<()> { | 
|  | encoder.debug_check_bounds::<SuperFooResponse>(offset); | 
|  | unsafe { | 
|  | // Copy the object into the buffer. | 
|  | let buf_ptr = encoder.buf.as_mut_ptr().add(offset); | 
|  | (buf_ptr as *mut SuperFooResponse) | 
|  | .write_unaligned((self as *const SuperFooResponse).read()); | 
|  | // Zero out padding regions. Unlike `fidl_struct_impl_noncopy!`, this must be | 
|  | // done second because the memcpy will write garbage to these bytes. | 
|  | } | 
|  | Ok(()) | 
|  | } | 
|  | } | 
|  | unsafe impl<D: fidl::encoding::ResourceDialect, T0: fidl::encoding::Encode<i64, D>> | 
|  | fidl::encoding::Encode<SuperFooResponse, D> for (T0,) | 
|  | { | 
|  | #[inline] | 
|  | unsafe fn encode( | 
|  | self, | 
|  | encoder: &mut fidl::encoding::Encoder<'_, D>, | 
|  | offset: usize, | 
|  | depth: fidl::encoding::Depth, | 
|  | ) -> fidl::Result<()> { | 
|  | encoder.debug_check_bounds::<SuperFooResponse>(offset); | 
|  | // Zero out padding regions. There's no need to apply masks | 
|  | // because the unmasked parts will be overwritten by fields. | 
|  | // Write the fields. | 
|  | self.0.encode(encoder, offset + 0, depth)?; | 
|  | Ok(()) | 
|  | } | 
|  | } | 
|  |  | 
|  | impl<D: fidl::encoding::ResourceDialect> fidl::encoding::Decode<Self, D> for SuperFooResponse { | 
|  | #[inline(always)] | 
|  | fn new_empty() -> Self { | 
|  | Self { y: fidl::new_empty!(i64, D) } | 
|  | } | 
|  |  | 
|  | #[inline] | 
|  | unsafe fn decode( | 
|  | &mut self, | 
|  | decoder: &mut fidl::encoding::Decoder<'_, D>, | 
|  | offset: usize, | 
|  | _depth: fidl::encoding::Depth, | 
|  | ) -> fidl::Result<()> { | 
|  | decoder.debug_check_bounds::<Self>(offset); | 
|  | let buf_ptr = unsafe { decoder.buf.as_ptr().add(offset) }; | 
|  | // Verify that padding bytes are zero. | 
|  | // Copy from the buffer into the object. | 
|  | unsafe { | 
|  | std::ptr::copy_nonoverlapping(buf_ptr, self as *mut Self as *mut u8, 8); | 
|  | } | 
|  | Ok(()) | 
|  | } | 
|  | } | 
|  | } |