1#![warn(clippy::all)]
4#![allow(unused_parens, unused_mut, unused_imports, nonstandard_style)]
5
6use bitflags::bitflags;
7use fidl::client::QueryResponseFut;
8use fidl::encoding::{MessageBufFor, ProxyChannelBox, ResourceDialect};
9use fidl::endpoints::{ControlHandle as _, Responder as _};
10pub use fidl_fuchsia_hardware_sockettunnel__common::*;
11use futures::future::{self, MaybeDone, TryFutureExt};
12use zx_status;
13
14#[derive(Debug, Default, PartialEq)]
15pub struct DeviceRegisterSocketRequest {
16 pub server_socket: Option<fidl::Socket>,
17 pub socket_label: Option<String>,
18 #[doc(hidden)]
19 pub __source_breaking: fidl::marker::SourceBreaking,
20}
21
22impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
23 for DeviceRegisterSocketRequest
24{
25}
26
27#[derive(Debug, Copy, Clone, Eq, PartialEq, Ord, PartialOrd, Hash)]
28pub struct DeviceMarker;
29
30impl fidl::endpoints::ProtocolMarker for DeviceMarker {
31 type Proxy = DeviceProxy;
32 type RequestStream = DeviceRequestStream;
33 #[cfg(target_os = "fuchsia")]
34 type SynchronousProxy = DeviceSynchronousProxy;
35
36 const DEBUG_NAME: &'static str = "fuchsia.hardware.sockettunnel.Device";
37}
38impl fidl::endpoints::DiscoverableProtocolMarker for DeviceMarker {}
39pub type DeviceRegisterSocketResult = Result<(), i32>;
40
41pub trait DeviceProxyInterface: Send + Sync {
42 type RegisterSocketResponseFut: std::future::Future<Output = Result<DeviceRegisterSocketResult, fidl::Error>>
43 + Send;
44 fn r#register_socket(
45 &self,
46 payload: DeviceRegisterSocketRequest,
47 ) -> Self::RegisterSocketResponseFut;
48}
49#[derive(Debug)]
50#[cfg(target_os = "fuchsia")]
51pub struct DeviceSynchronousProxy {
52 client: fidl::client::sync::Client,
53}
54
55#[cfg(target_os = "fuchsia")]
56impl fidl::endpoints::SynchronousProxy for DeviceSynchronousProxy {
57 type Proxy = DeviceProxy;
58 type Protocol = DeviceMarker;
59
60 fn from_channel(inner: fidl::Channel) -> Self {
61 Self::new(inner)
62 }
63
64 fn into_channel(self) -> fidl::Channel {
65 self.client.into_channel()
66 }
67
68 fn as_channel(&self) -> &fidl::Channel {
69 self.client.as_channel()
70 }
71}
72
73#[cfg(target_os = "fuchsia")]
74impl DeviceSynchronousProxy {
75 pub fn new(channel: fidl::Channel) -> Self {
76 let protocol_name = <DeviceMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME;
77 Self { client: fidl::client::sync::Client::new(channel, protocol_name) }
78 }
79
80 pub fn into_channel(self) -> fidl::Channel {
81 self.client.into_channel()
82 }
83
84 pub fn wait_for_event(
87 &self,
88 deadline: zx::MonotonicInstant,
89 ) -> Result<DeviceEvent, fidl::Error> {
90 DeviceEvent::decode(self.client.wait_for_event(deadline)?)
91 }
92
93 pub fn r#register_socket(
94 &self,
95 mut payload: DeviceRegisterSocketRequest,
96 ___deadline: zx::MonotonicInstant,
97 ) -> Result<DeviceRegisterSocketResult, fidl::Error> {
98 let _response = self.client.send_query::<
99 DeviceRegisterSocketRequest,
100 fidl::encoding::FlexibleResultType<fidl::encoding::EmptyStruct, i32>,
101 >(
102 &mut payload,
103 0x4b2c4d82dae82c6d,
104 fidl::encoding::DynamicFlags::FLEXIBLE,
105 ___deadline,
106 )?
107 .into_result::<DeviceMarker>("register_socket")?;
108 Ok(_response.map(|x| x))
109 }
110}
111
112#[cfg(target_os = "fuchsia")]
113impl From<DeviceSynchronousProxy> for zx::NullableHandle {
114 fn from(value: DeviceSynchronousProxy) -> Self {
115 value.into_channel().into()
116 }
117}
118
119#[cfg(target_os = "fuchsia")]
120impl From<fidl::Channel> for DeviceSynchronousProxy {
121 fn from(value: fidl::Channel) -> Self {
122 Self::new(value)
123 }
124}
125
126#[cfg(target_os = "fuchsia")]
127impl fidl::endpoints::FromClient for DeviceSynchronousProxy {
128 type Protocol = DeviceMarker;
129
130 fn from_client(value: fidl::endpoints::ClientEnd<DeviceMarker>) -> Self {
131 Self::new(value.into_channel())
132 }
133}
134
135#[derive(Debug, Clone)]
136pub struct DeviceProxy {
137 client: fidl::client::Client<fidl::encoding::DefaultFuchsiaResourceDialect>,
138}
139
140impl fidl::endpoints::Proxy for DeviceProxy {
141 type Protocol = DeviceMarker;
142
143 fn from_channel(inner: ::fidl::AsyncChannel) -> Self {
144 Self::new(inner)
145 }
146
147 fn into_channel(self) -> Result<::fidl::AsyncChannel, Self> {
148 self.client.into_channel().map_err(|client| Self { client })
149 }
150
151 fn as_channel(&self) -> &::fidl::AsyncChannel {
152 self.client.as_channel()
153 }
154}
155
156impl DeviceProxy {
157 pub fn new(channel: ::fidl::AsyncChannel) -> Self {
159 let protocol_name = <DeviceMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME;
160 Self { client: fidl::client::Client::new(channel, protocol_name) }
161 }
162
163 pub fn take_event_stream(&self) -> DeviceEventStream {
169 DeviceEventStream { event_receiver: self.client.take_event_receiver() }
170 }
171
172 pub fn r#register_socket(
173 &self,
174 mut payload: DeviceRegisterSocketRequest,
175 ) -> fidl::client::QueryResponseFut<
176 DeviceRegisterSocketResult,
177 fidl::encoding::DefaultFuchsiaResourceDialect,
178 > {
179 DeviceProxyInterface::r#register_socket(self, payload)
180 }
181}
182
183impl DeviceProxyInterface for DeviceProxy {
184 type RegisterSocketResponseFut = fidl::client::QueryResponseFut<
185 DeviceRegisterSocketResult,
186 fidl::encoding::DefaultFuchsiaResourceDialect,
187 >;
188 fn r#register_socket(
189 &self,
190 mut payload: DeviceRegisterSocketRequest,
191 ) -> Self::RegisterSocketResponseFut {
192 fn _decode(
193 mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
194 ) -> Result<DeviceRegisterSocketResult, fidl::Error> {
195 let _response = fidl::client::decode_transaction_body::<
196 fidl::encoding::FlexibleResultType<fidl::encoding::EmptyStruct, i32>,
197 fidl::encoding::DefaultFuchsiaResourceDialect,
198 0x4b2c4d82dae82c6d,
199 >(_buf?)?
200 .into_result::<DeviceMarker>("register_socket")?;
201 Ok(_response.map(|x| x))
202 }
203 self.client
204 .send_query_and_decode::<DeviceRegisterSocketRequest, DeviceRegisterSocketResult>(
205 &mut payload,
206 0x4b2c4d82dae82c6d,
207 fidl::encoding::DynamicFlags::FLEXIBLE,
208 _decode,
209 )
210 }
211}
212
213pub struct DeviceEventStream {
214 event_receiver: fidl::client::EventReceiver<fidl::encoding::DefaultFuchsiaResourceDialect>,
215}
216
217impl std::marker::Unpin for DeviceEventStream {}
218
219impl futures::stream::FusedStream for DeviceEventStream {
220 fn is_terminated(&self) -> bool {
221 self.event_receiver.is_terminated()
222 }
223}
224
225impl futures::Stream for DeviceEventStream {
226 type Item = Result<DeviceEvent, fidl::Error>;
227
228 fn poll_next(
229 mut self: std::pin::Pin<&mut Self>,
230 cx: &mut std::task::Context<'_>,
231 ) -> std::task::Poll<Option<Self::Item>> {
232 match futures::ready!(futures::stream::StreamExt::poll_next_unpin(
233 &mut self.event_receiver,
234 cx
235 )?) {
236 Some(buf) => std::task::Poll::Ready(Some(DeviceEvent::decode(buf))),
237 None => std::task::Poll::Ready(None),
238 }
239 }
240}
241
242#[derive(Debug)]
243pub enum DeviceEvent {
244 #[non_exhaustive]
245 _UnknownEvent {
246 ordinal: u64,
248 },
249}
250
251impl DeviceEvent {
252 fn decode(
254 mut buf: <fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc,
255 ) -> Result<DeviceEvent, fidl::Error> {
256 let (bytes, _handles) = buf.split_mut();
257 let (tx_header, _body_bytes) = fidl::encoding::decode_transaction_header(bytes)?;
258 debug_assert_eq!(tx_header.tx_id, 0);
259 match tx_header.ordinal {
260 _ if tx_header.dynamic_flags().contains(fidl::encoding::DynamicFlags::FLEXIBLE) => {
261 Ok(DeviceEvent::_UnknownEvent { ordinal: tx_header.ordinal })
262 }
263 _ => Err(fidl::Error::UnknownOrdinal {
264 ordinal: tx_header.ordinal,
265 protocol_name: <DeviceMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME,
266 }),
267 }
268 }
269}
270
271pub struct DeviceRequestStream {
273 inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
274 is_terminated: bool,
275}
276
277impl std::marker::Unpin for DeviceRequestStream {}
278
279impl futures::stream::FusedStream for DeviceRequestStream {
280 fn is_terminated(&self) -> bool {
281 self.is_terminated
282 }
283}
284
285impl fidl::endpoints::RequestStream for DeviceRequestStream {
286 type Protocol = DeviceMarker;
287 type ControlHandle = DeviceControlHandle;
288
289 fn from_channel(channel: ::fidl::AsyncChannel) -> Self {
290 Self { inner: std::sync::Arc::new(fidl::ServeInner::new(channel)), is_terminated: false }
291 }
292
293 fn control_handle(&self) -> Self::ControlHandle {
294 DeviceControlHandle { inner: self.inner.clone() }
295 }
296
297 fn into_inner(
298 self,
299 ) -> (::std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>, bool)
300 {
301 (self.inner, self.is_terminated)
302 }
303
304 fn from_inner(
305 inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
306 is_terminated: bool,
307 ) -> Self {
308 Self { inner, is_terminated }
309 }
310}
311
312impl futures::Stream for DeviceRequestStream {
313 type Item = Result<DeviceRequest, fidl::Error>;
314
315 fn poll_next(
316 mut self: std::pin::Pin<&mut Self>,
317 cx: &mut std::task::Context<'_>,
318 ) -> std::task::Poll<Option<Self::Item>> {
319 let this = &mut *self;
320 if this.inner.check_shutdown(cx) {
321 this.is_terminated = true;
322 return std::task::Poll::Ready(None);
323 }
324 if this.is_terminated {
325 panic!("polled DeviceRequestStream after completion");
326 }
327 fidl::encoding::with_tls_decode_buf::<_, fidl::encoding::DefaultFuchsiaResourceDialect>(
328 |bytes, handles| {
329 match this.inner.channel().read_etc(cx, bytes, handles) {
330 std::task::Poll::Ready(Ok(())) => {}
331 std::task::Poll::Pending => return std::task::Poll::Pending,
332 std::task::Poll::Ready(Err(zx_status::Status::PEER_CLOSED)) => {
333 this.is_terminated = true;
334 return std::task::Poll::Ready(None);
335 }
336 std::task::Poll::Ready(Err(e)) => {
337 return std::task::Poll::Ready(Some(Err(fidl::Error::ServerRequestRead(
338 e.into(),
339 ))));
340 }
341 }
342
343 let (header, _body_bytes) = fidl::encoding::decode_transaction_header(bytes)?;
345
346 std::task::Poll::Ready(Some(match header.ordinal {
347 0x4b2c4d82dae82c6d => {
348 header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
349 let mut req = fidl::new_empty!(
350 DeviceRegisterSocketRequest,
351 fidl::encoding::DefaultFuchsiaResourceDialect
352 );
353 fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<DeviceRegisterSocketRequest>(&header, _body_bytes, handles, &mut req)?;
354 let control_handle = DeviceControlHandle { inner: this.inner.clone() };
355 Ok(DeviceRequest::RegisterSocket {
356 payload: req,
357 responder: DeviceRegisterSocketResponder {
358 control_handle: std::mem::ManuallyDrop::new(control_handle),
359 tx_id: header.tx_id,
360 },
361 })
362 }
363 _ if header.tx_id == 0
364 && header
365 .dynamic_flags()
366 .contains(fidl::encoding::DynamicFlags::FLEXIBLE) =>
367 {
368 Ok(DeviceRequest::_UnknownMethod {
369 ordinal: header.ordinal,
370 control_handle: DeviceControlHandle { inner: this.inner.clone() },
371 method_type: fidl::MethodType::OneWay,
372 })
373 }
374 _ if header
375 .dynamic_flags()
376 .contains(fidl::encoding::DynamicFlags::FLEXIBLE) =>
377 {
378 this.inner.send_framework_err(
379 fidl::encoding::FrameworkErr::UnknownMethod,
380 header.tx_id,
381 header.ordinal,
382 header.dynamic_flags(),
383 (bytes, handles),
384 )?;
385 Ok(DeviceRequest::_UnknownMethod {
386 ordinal: header.ordinal,
387 control_handle: DeviceControlHandle { inner: this.inner.clone() },
388 method_type: fidl::MethodType::TwoWay,
389 })
390 }
391 _ => Err(fidl::Error::UnknownOrdinal {
392 ordinal: header.ordinal,
393 protocol_name:
394 <DeviceMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME,
395 }),
396 }))
397 },
398 )
399 }
400}
401
402#[derive(Debug)]
405pub enum DeviceRequest {
406 RegisterSocket {
407 payload: DeviceRegisterSocketRequest,
408 responder: DeviceRegisterSocketResponder,
409 },
410 #[non_exhaustive]
412 _UnknownMethod {
413 ordinal: u64,
415 control_handle: DeviceControlHandle,
416 method_type: fidl::MethodType,
417 },
418}
419
420impl DeviceRequest {
421 #[allow(irrefutable_let_patterns)]
422 pub fn into_register_socket(
423 self,
424 ) -> Option<(DeviceRegisterSocketRequest, DeviceRegisterSocketResponder)> {
425 if let DeviceRequest::RegisterSocket { payload, responder } = self {
426 Some((payload, responder))
427 } else {
428 None
429 }
430 }
431
432 pub fn method_name(&self) -> &'static str {
434 match *self {
435 DeviceRequest::RegisterSocket { .. } => "register_socket",
436 DeviceRequest::_UnknownMethod { method_type: fidl::MethodType::OneWay, .. } => {
437 "unknown one-way method"
438 }
439 DeviceRequest::_UnknownMethod { method_type: fidl::MethodType::TwoWay, .. } => {
440 "unknown two-way method"
441 }
442 }
443 }
444}
445
446#[derive(Debug, Clone)]
447pub struct DeviceControlHandle {
448 inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
449}
450
451impl fidl::endpoints::ControlHandle for DeviceControlHandle {
452 fn shutdown(&self) {
453 self.inner.shutdown()
454 }
455
456 fn shutdown_with_epitaph(&self, status: zx_status::Status) {
457 self.inner.shutdown_with_epitaph(status)
458 }
459
460 fn is_closed(&self) -> bool {
461 self.inner.channel().is_closed()
462 }
463 fn on_closed(&self) -> fidl::OnSignalsRef<'_> {
464 self.inner.channel().on_closed()
465 }
466
467 #[cfg(target_os = "fuchsia")]
468 fn signal_peer(
469 &self,
470 clear_mask: zx::Signals,
471 set_mask: zx::Signals,
472 ) -> Result<(), zx_status::Status> {
473 use fidl::Peered;
474 self.inner.channel().signal_peer(clear_mask, set_mask)
475 }
476}
477
478impl DeviceControlHandle {}
479
480#[must_use = "FIDL methods require a response to be sent"]
481#[derive(Debug)]
482pub struct DeviceRegisterSocketResponder {
483 control_handle: std::mem::ManuallyDrop<DeviceControlHandle>,
484 tx_id: u32,
485}
486
487impl std::ops::Drop for DeviceRegisterSocketResponder {
491 fn drop(&mut self) {
492 self.control_handle.shutdown();
493 unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
495 }
496}
497
498impl fidl::endpoints::Responder for DeviceRegisterSocketResponder {
499 type ControlHandle = DeviceControlHandle;
500
501 fn control_handle(&self) -> &DeviceControlHandle {
502 &self.control_handle
503 }
504
505 fn drop_without_shutdown(mut self) {
506 unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
508 std::mem::forget(self);
510 }
511}
512
513impl DeviceRegisterSocketResponder {
514 pub fn send(self, mut result: Result<(), i32>) -> Result<(), fidl::Error> {
518 let _result = self.send_raw(result);
519 if _result.is_err() {
520 self.control_handle.shutdown();
521 }
522 self.drop_without_shutdown();
523 _result
524 }
525
526 pub fn send_no_shutdown_on_err(self, mut result: Result<(), i32>) -> Result<(), fidl::Error> {
528 let _result = self.send_raw(result);
529 self.drop_without_shutdown();
530 _result
531 }
532
533 fn send_raw(&self, mut result: Result<(), i32>) -> Result<(), fidl::Error> {
534 self.control_handle.inner.send::<fidl::encoding::FlexibleResultType<
535 fidl::encoding::EmptyStruct,
536 i32,
537 >>(
538 fidl::encoding::FlexibleResult::new(result),
539 self.tx_id,
540 0x4b2c4d82dae82c6d,
541 fidl::encoding::DynamicFlags::FLEXIBLE,
542 )
543 }
544}
545
546#[derive(Debug, Copy, Clone, Eq, PartialEq, Ord, PartialOrd, Hash)]
547pub struct ServiceMarker;
548
549#[cfg(target_os = "fuchsia")]
550impl fidl::endpoints::ServiceMarker for ServiceMarker {
551 type Proxy = ServiceProxy;
552 type Request = ServiceRequest;
553 const SERVICE_NAME: &'static str = "fuchsia.hardware.sockettunnel.Service";
554}
555
556#[cfg(target_os = "fuchsia")]
559pub enum ServiceRequest {
560 SocketTunnel(DeviceRequestStream),
561}
562
563#[cfg(target_os = "fuchsia")]
564impl fidl::endpoints::ServiceRequest for ServiceRequest {
565 type Service = ServiceMarker;
566
567 fn dispatch(name: &str, _channel: fidl::AsyncChannel) -> Self {
568 match name {
569 "socket_tunnel" => Self::SocketTunnel(
570 <DeviceRequestStream as fidl::endpoints::RequestStream>::from_channel(_channel),
571 ),
572 _ => panic!("no such member protocol name for service Service"),
573 }
574 }
575
576 fn member_names() -> &'static [&'static str] {
577 &["socket_tunnel"]
578 }
579}
580#[cfg(target_os = "fuchsia")]
581pub struct ServiceProxy(#[allow(dead_code)] Box<dyn fidl::endpoints::MemberOpener>);
582
583#[cfg(target_os = "fuchsia")]
584impl fidl::endpoints::ServiceProxy for ServiceProxy {
585 type Service = ServiceMarker;
586
587 fn from_member_opener(opener: Box<dyn fidl::endpoints::MemberOpener>) -> Self {
588 Self(opener)
589 }
590}
591
592#[cfg(target_os = "fuchsia")]
593impl ServiceProxy {
594 pub fn connect_to_socket_tunnel(&self) -> Result<DeviceProxy, fidl::Error> {
595 let (proxy, server_end) = fidl::endpoints::create_proxy::<DeviceMarker>();
596 self.connect_channel_to_socket_tunnel(server_end)?;
597 Ok(proxy)
598 }
599
600 pub fn connect_to_socket_tunnel_sync(&self) -> Result<DeviceSynchronousProxy, fidl::Error> {
603 let (proxy, server_end) = fidl::endpoints::create_sync_proxy::<DeviceMarker>();
604 self.connect_channel_to_socket_tunnel(server_end)?;
605 Ok(proxy)
606 }
607
608 pub fn connect_channel_to_socket_tunnel(
611 &self,
612 server_end: fidl::endpoints::ServerEnd<DeviceMarker>,
613 ) -> Result<(), fidl::Error> {
614 self.0.open_member("socket_tunnel", server_end.into_channel())
615 }
616
617 pub fn instance_name(&self) -> &str {
618 self.0.instance_name()
619 }
620}
621
622mod internal {
623 use super::*;
624
625 impl DeviceRegisterSocketRequest {
626 #[inline(always)]
627 fn max_ordinal_present(&self) -> u64 {
628 if let Some(_) = self.socket_label {
629 return 2;
630 }
631 if let Some(_) = self.server_socket {
632 return 1;
633 }
634 0
635 }
636 }
637
638 impl fidl::encoding::ResourceTypeMarker for DeviceRegisterSocketRequest {
639 type Borrowed<'a> = &'a mut Self;
640 fn take_or_borrow<'a>(
641 value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
642 ) -> Self::Borrowed<'a> {
643 value
644 }
645 }
646
647 unsafe impl fidl::encoding::TypeMarker for DeviceRegisterSocketRequest {
648 type Owned = Self;
649
650 #[inline(always)]
651 fn inline_align(_context: fidl::encoding::Context) -> usize {
652 8
653 }
654
655 #[inline(always)]
656 fn inline_size(_context: fidl::encoding::Context) -> usize {
657 16
658 }
659 }
660
661 unsafe impl
662 fidl::encoding::Encode<
663 DeviceRegisterSocketRequest,
664 fidl::encoding::DefaultFuchsiaResourceDialect,
665 > for &mut DeviceRegisterSocketRequest
666 {
667 unsafe fn encode(
668 self,
669 encoder: &mut fidl::encoding::Encoder<
670 '_,
671 fidl::encoding::DefaultFuchsiaResourceDialect,
672 >,
673 offset: usize,
674 mut depth: fidl::encoding::Depth,
675 ) -> fidl::Result<()> {
676 encoder.debug_check_bounds::<DeviceRegisterSocketRequest>(offset);
677 let max_ordinal: u64 = self.max_ordinal_present();
679 encoder.write_num(max_ordinal, offset);
680 encoder.write_num(fidl::encoding::ALLOC_PRESENT_U64, offset + 8);
681 if max_ordinal == 0 {
683 return Ok(());
684 }
685 depth.increment()?;
686 let envelope_size = 8;
687 let bytes_len = max_ordinal as usize * envelope_size;
688 #[allow(unused_variables)]
689 let offset = encoder.out_of_line_offset(bytes_len);
690 let mut _prev_end_offset: usize = 0;
691 if 1 > max_ordinal {
692 return Ok(());
693 }
694
695 let cur_offset: usize = (1 - 1) * envelope_size;
698
699 encoder.padding(offset + _prev_end_offset, cur_offset - _prev_end_offset);
701
702 fidl::encoding::encode_in_envelope_optional::<
707 fidl::encoding::HandleType<
708 fidl::Socket,
709 { fidl::ObjectType::SOCKET.into_raw() },
710 2147483648,
711 >,
712 fidl::encoding::DefaultFuchsiaResourceDialect,
713 >(
714 self.server_socket.as_mut().map(
715 <fidl::encoding::HandleType<
716 fidl::Socket,
717 { fidl::ObjectType::SOCKET.into_raw() },
718 2147483648,
719 > as fidl::encoding::ResourceTypeMarker>::take_or_borrow,
720 ),
721 encoder,
722 offset + cur_offset,
723 depth,
724 )?;
725
726 _prev_end_offset = cur_offset + envelope_size;
727 if 2 > max_ordinal {
728 return Ok(());
729 }
730
731 let cur_offset: usize = (2 - 1) * envelope_size;
734
735 encoder.padding(offset + _prev_end_offset, cur_offset - _prev_end_offset);
737
738 fidl::encoding::encode_in_envelope_optional::<
743 fidl::encoding::UnboundedString,
744 fidl::encoding::DefaultFuchsiaResourceDialect,
745 >(
746 self.socket_label.as_ref().map(
747 <fidl::encoding::UnboundedString as fidl::encoding::ValueTypeMarker>::borrow,
748 ),
749 encoder,
750 offset + cur_offset,
751 depth,
752 )?;
753
754 _prev_end_offset = cur_offset + envelope_size;
755
756 Ok(())
757 }
758 }
759
760 impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
761 for DeviceRegisterSocketRequest
762 {
763 #[inline(always)]
764 fn new_empty() -> Self {
765 Self::default()
766 }
767
768 unsafe fn decode(
769 &mut self,
770 decoder: &mut fidl::encoding::Decoder<
771 '_,
772 fidl::encoding::DefaultFuchsiaResourceDialect,
773 >,
774 offset: usize,
775 mut depth: fidl::encoding::Depth,
776 ) -> fidl::Result<()> {
777 decoder.debug_check_bounds::<Self>(offset);
778 let len = match fidl::encoding::decode_vector_header(decoder, offset)? {
779 None => return Err(fidl::Error::NotNullable),
780 Some(len) => len,
781 };
782 if len == 0 {
784 return Ok(());
785 };
786 depth.increment()?;
787 let envelope_size = 8;
788 let bytes_len = len * envelope_size;
789 let offset = decoder.out_of_line_offset(bytes_len)?;
790 let mut _next_ordinal_to_read = 0;
792 let mut next_offset = offset;
793 let end_offset = offset + bytes_len;
794 _next_ordinal_to_read += 1;
795 if next_offset >= end_offset {
796 return Ok(());
797 }
798
799 while _next_ordinal_to_read < 1 {
801 fidl::encoding::decode_unknown_envelope(decoder, next_offset, depth)?;
802 _next_ordinal_to_read += 1;
803 next_offset += envelope_size;
804 }
805
806 let next_out_of_line = decoder.next_out_of_line();
807 let handles_before = decoder.remaining_handles();
808 if let Some((inlined, num_bytes, num_handles)) =
809 fidl::encoding::decode_envelope_header(decoder, next_offset)?
810 {
811 let member_inline_size = <fidl::encoding::HandleType<
812 fidl::Socket,
813 { fidl::ObjectType::SOCKET.into_raw() },
814 2147483648,
815 > as fidl::encoding::TypeMarker>::inline_size(
816 decoder.context
817 );
818 if inlined != (member_inline_size <= 4) {
819 return Err(fidl::Error::InvalidInlineBitInEnvelope);
820 }
821 let inner_offset;
822 let mut inner_depth = depth.clone();
823 if inlined {
824 decoder.check_inline_envelope_padding(next_offset, member_inline_size)?;
825 inner_offset = next_offset;
826 } else {
827 inner_offset = decoder.out_of_line_offset(member_inline_size)?;
828 inner_depth.increment()?;
829 }
830 let val_ref =
831 self.server_socket.get_or_insert_with(|| fidl::new_empty!(fidl::encoding::HandleType<fidl::Socket, { fidl::ObjectType::SOCKET.into_raw() }, 2147483648>, fidl::encoding::DefaultFuchsiaResourceDialect));
832 fidl::decode!(fidl::encoding::HandleType<fidl::Socket, { fidl::ObjectType::SOCKET.into_raw() }, 2147483648>, fidl::encoding::DefaultFuchsiaResourceDialect, val_ref, decoder, inner_offset, inner_depth)?;
833 if !inlined && decoder.next_out_of_line() != next_out_of_line + (num_bytes as usize)
834 {
835 return Err(fidl::Error::InvalidNumBytesInEnvelope);
836 }
837 if handles_before != decoder.remaining_handles() + (num_handles as usize) {
838 return Err(fidl::Error::InvalidNumHandlesInEnvelope);
839 }
840 }
841
842 next_offset += envelope_size;
843 _next_ordinal_to_read += 1;
844 if next_offset >= end_offset {
845 return Ok(());
846 }
847
848 while _next_ordinal_to_read < 2 {
850 fidl::encoding::decode_unknown_envelope(decoder, next_offset, depth)?;
851 _next_ordinal_to_read += 1;
852 next_offset += envelope_size;
853 }
854
855 let next_out_of_line = decoder.next_out_of_line();
856 let handles_before = decoder.remaining_handles();
857 if let Some((inlined, num_bytes, num_handles)) =
858 fidl::encoding::decode_envelope_header(decoder, next_offset)?
859 {
860 let member_inline_size =
861 <fidl::encoding::UnboundedString as fidl::encoding::TypeMarker>::inline_size(
862 decoder.context,
863 );
864 if inlined != (member_inline_size <= 4) {
865 return Err(fidl::Error::InvalidInlineBitInEnvelope);
866 }
867 let inner_offset;
868 let mut inner_depth = depth.clone();
869 if inlined {
870 decoder.check_inline_envelope_padding(next_offset, member_inline_size)?;
871 inner_offset = next_offset;
872 } else {
873 inner_offset = decoder.out_of_line_offset(member_inline_size)?;
874 inner_depth.increment()?;
875 }
876 let val_ref = self.socket_label.get_or_insert_with(|| {
877 fidl::new_empty!(
878 fidl::encoding::UnboundedString,
879 fidl::encoding::DefaultFuchsiaResourceDialect
880 )
881 });
882 fidl::decode!(
883 fidl::encoding::UnboundedString,
884 fidl::encoding::DefaultFuchsiaResourceDialect,
885 val_ref,
886 decoder,
887 inner_offset,
888 inner_depth
889 )?;
890 if !inlined && decoder.next_out_of_line() != next_out_of_line + (num_bytes as usize)
891 {
892 return Err(fidl::Error::InvalidNumBytesInEnvelope);
893 }
894 if handles_before != decoder.remaining_handles() + (num_handles as usize) {
895 return Err(fidl::Error::InvalidNumHandlesInEnvelope);
896 }
897 }
898
899 next_offset += envelope_size;
900
901 while next_offset < end_offset {
903 _next_ordinal_to_read += 1;
904 fidl::encoding::decode_unknown_envelope(decoder, next_offset, depth)?;
905 next_offset += envelope_size;
906 }
907
908 Ok(())
909 }
910 }
911}