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::Handle {
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 fn shutdown_with_epitaph(&self, status: zx_status::Status) {
456 self.inner.shutdown_with_epitaph(status)
457 }
458
459 fn is_closed(&self) -> bool {
460 self.inner.channel().is_closed()
461 }
462 fn on_closed(&self) -> fidl::OnSignalsRef<'_> {
463 self.inner.channel().on_closed()
464 }
465
466 #[cfg(target_os = "fuchsia")]
467 fn signal_peer(
468 &self,
469 clear_mask: zx::Signals,
470 set_mask: zx::Signals,
471 ) -> Result<(), zx_status::Status> {
472 use fidl::Peered;
473 self.inner.channel().signal_peer(clear_mask, set_mask)
474 }
475}
476
477impl DeviceControlHandle {}
478
479#[must_use = "FIDL methods require a response to be sent"]
480#[derive(Debug)]
481pub struct DeviceRegisterSocketResponder {
482 control_handle: std::mem::ManuallyDrop<DeviceControlHandle>,
483 tx_id: u32,
484}
485
486impl std::ops::Drop for DeviceRegisterSocketResponder {
490 fn drop(&mut self) {
491 self.control_handle.shutdown();
492 unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
494 }
495}
496
497impl fidl::endpoints::Responder for DeviceRegisterSocketResponder {
498 type ControlHandle = DeviceControlHandle;
499
500 fn control_handle(&self) -> &DeviceControlHandle {
501 &self.control_handle
502 }
503
504 fn drop_without_shutdown(mut self) {
505 unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
507 std::mem::forget(self);
509 }
510}
511
512impl DeviceRegisterSocketResponder {
513 pub fn send(self, mut result: Result<(), i32>) -> Result<(), fidl::Error> {
517 let _result = self.send_raw(result);
518 if _result.is_err() {
519 self.control_handle.shutdown();
520 }
521 self.drop_without_shutdown();
522 _result
523 }
524
525 pub fn send_no_shutdown_on_err(self, mut result: Result<(), i32>) -> Result<(), fidl::Error> {
527 let _result = self.send_raw(result);
528 self.drop_without_shutdown();
529 _result
530 }
531
532 fn send_raw(&self, mut result: Result<(), i32>) -> Result<(), fidl::Error> {
533 self.control_handle.inner.send::<fidl::encoding::FlexibleResultType<
534 fidl::encoding::EmptyStruct,
535 i32,
536 >>(
537 fidl::encoding::FlexibleResult::new(result),
538 self.tx_id,
539 0x4b2c4d82dae82c6d,
540 fidl::encoding::DynamicFlags::FLEXIBLE,
541 )
542 }
543}
544
545#[derive(Debug, Copy, Clone, Eq, PartialEq, Ord, PartialOrd, Hash)]
546pub struct ServiceMarker;
547
548#[cfg(target_os = "fuchsia")]
549impl fidl::endpoints::ServiceMarker for ServiceMarker {
550 type Proxy = ServiceProxy;
551 type Request = ServiceRequest;
552 const SERVICE_NAME: &'static str = "fuchsia.hardware.sockettunnel.Service";
553}
554
555#[cfg(target_os = "fuchsia")]
558pub enum ServiceRequest {
559 SocketTunnel(DeviceRequestStream),
560}
561
562#[cfg(target_os = "fuchsia")]
563impl fidl::endpoints::ServiceRequest for ServiceRequest {
564 type Service = ServiceMarker;
565
566 fn dispatch(name: &str, _channel: fidl::AsyncChannel) -> Self {
567 match name {
568 "socket_tunnel" => Self::SocketTunnel(
569 <DeviceRequestStream as fidl::endpoints::RequestStream>::from_channel(_channel),
570 ),
571 _ => panic!("no such member protocol name for service Service"),
572 }
573 }
574
575 fn member_names() -> &'static [&'static str] {
576 &["socket_tunnel"]
577 }
578}
579#[cfg(target_os = "fuchsia")]
580pub struct ServiceProxy(#[allow(dead_code)] Box<dyn fidl::endpoints::MemberOpener>);
581
582#[cfg(target_os = "fuchsia")]
583impl fidl::endpoints::ServiceProxy for ServiceProxy {
584 type Service = ServiceMarker;
585
586 fn from_member_opener(opener: Box<dyn fidl::endpoints::MemberOpener>) -> Self {
587 Self(opener)
588 }
589}
590
591#[cfg(target_os = "fuchsia")]
592impl ServiceProxy {
593 pub fn connect_to_socket_tunnel(&self) -> Result<DeviceProxy, fidl::Error> {
594 let (proxy, server_end) = fidl::endpoints::create_proxy::<DeviceMarker>();
595 self.connect_channel_to_socket_tunnel(server_end)?;
596 Ok(proxy)
597 }
598
599 pub fn connect_to_socket_tunnel_sync(&self) -> Result<DeviceSynchronousProxy, fidl::Error> {
602 let (proxy, server_end) = fidl::endpoints::create_sync_proxy::<DeviceMarker>();
603 self.connect_channel_to_socket_tunnel(server_end)?;
604 Ok(proxy)
605 }
606
607 pub fn connect_channel_to_socket_tunnel(
610 &self,
611 server_end: fidl::endpoints::ServerEnd<DeviceMarker>,
612 ) -> Result<(), fidl::Error> {
613 self.0.open_member("socket_tunnel", server_end.into_channel())
614 }
615
616 pub fn instance_name(&self) -> &str {
617 self.0.instance_name()
618 }
619}
620
621mod internal {
622 use super::*;
623
624 impl DeviceRegisterSocketRequest {
625 #[inline(always)]
626 fn max_ordinal_present(&self) -> u64 {
627 if let Some(_) = self.socket_label {
628 return 2;
629 }
630 if let Some(_) = self.server_socket {
631 return 1;
632 }
633 0
634 }
635 }
636
637 impl fidl::encoding::ResourceTypeMarker for DeviceRegisterSocketRequest {
638 type Borrowed<'a> = &'a mut Self;
639 fn take_or_borrow<'a>(
640 value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
641 ) -> Self::Borrowed<'a> {
642 value
643 }
644 }
645
646 unsafe impl fidl::encoding::TypeMarker for DeviceRegisterSocketRequest {
647 type Owned = Self;
648
649 #[inline(always)]
650 fn inline_align(_context: fidl::encoding::Context) -> usize {
651 8
652 }
653
654 #[inline(always)]
655 fn inline_size(_context: fidl::encoding::Context) -> usize {
656 16
657 }
658 }
659
660 unsafe impl
661 fidl::encoding::Encode<
662 DeviceRegisterSocketRequest,
663 fidl::encoding::DefaultFuchsiaResourceDialect,
664 > for &mut DeviceRegisterSocketRequest
665 {
666 unsafe fn encode(
667 self,
668 encoder: &mut fidl::encoding::Encoder<
669 '_,
670 fidl::encoding::DefaultFuchsiaResourceDialect,
671 >,
672 offset: usize,
673 mut depth: fidl::encoding::Depth,
674 ) -> fidl::Result<()> {
675 encoder.debug_check_bounds::<DeviceRegisterSocketRequest>(offset);
676 let max_ordinal: u64 = self.max_ordinal_present();
678 encoder.write_num(max_ordinal, offset);
679 encoder.write_num(fidl::encoding::ALLOC_PRESENT_U64, offset + 8);
680 if max_ordinal == 0 {
682 return Ok(());
683 }
684 depth.increment()?;
685 let envelope_size = 8;
686 let bytes_len = max_ordinal as usize * envelope_size;
687 #[allow(unused_variables)]
688 let offset = encoder.out_of_line_offset(bytes_len);
689 let mut _prev_end_offset: usize = 0;
690 if 1 > max_ordinal {
691 return Ok(());
692 }
693
694 let cur_offset: usize = (1 - 1) * envelope_size;
697
698 encoder.padding(offset + _prev_end_offset, cur_offset - _prev_end_offset);
700
701 fidl::encoding::encode_in_envelope_optional::<
706 fidl::encoding::HandleType<
707 fidl::Socket,
708 { fidl::ObjectType::SOCKET.into_raw() },
709 2147483648,
710 >,
711 fidl::encoding::DefaultFuchsiaResourceDialect,
712 >(
713 self.server_socket.as_mut().map(
714 <fidl::encoding::HandleType<
715 fidl::Socket,
716 { fidl::ObjectType::SOCKET.into_raw() },
717 2147483648,
718 > as fidl::encoding::ResourceTypeMarker>::take_or_borrow,
719 ),
720 encoder,
721 offset + cur_offset,
722 depth,
723 )?;
724
725 _prev_end_offset = cur_offset + envelope_size;
726 if 2 > max_ordinal {
727 return Ok(());
728 }
729
730 let cur_offset: usize = (2 - 1) * envelope_size;
733
734 encoder.padding(offset + _prev_end_offset, cur_offset - _prev_end_offset);
736
737 fidl::encoding::encode_in_envelope_optional::<
742 fidl::encoding::UnboundedString,
743 fidl::encoding::DefaultFuchsiaResourceDialect,
744 >(
745 self.socket_label.as_ref().map(
746 <fidl::encoding::UnboundedString as fidl::encoding::ValueTypeMarker>::borrow,
747 ),
748 encoder,
749 offset + cur_offset,
750 depth,
751 )?;
752
753 _prev_end_offset = cur_offset + envelope_size;
754
755 Ok(())
756 }
757 }
758
759 impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
760 for DeviceRegisterSocketRequest
761 {
762 #[inline(always)]
763 fn new_empty() -> Self {
764 Self::default()
765 }
766
767 unsafe fn decode(
768 &mut self,
769 decoder: &mut fidl::encoding::Decoder<
770 '_,
771 fidl::encoding::DefaultFuchsiaResourceDialect,
772 >,
773 offset: usize,
774 mut depth: fidl::encoding::Depth,
775 ) -> fidl::Result<()> {
776 decoder.debug_check_bounds::<Self>(offset);
777 let len = match fidl::encoding::decode_vector_header(decoder, offset)? {
778 None => return Err(fidl::Error::NotNullable),
779 Some(len) => len,
780 };
781 if len == 0 {
783 return Ok(());
784 };
785 depth.increment()?;
786 let envelope_size = 8;
787 let bytes_len = len * envelope_size;
788 let offset = decoder.out_of_line_offset(bytes_len)?;
789 let mut _next_ordinal_to_read = 0;
791 let mut next_offset = offset;
792 let end_offset = offset + bytes_len;
793 _next_ordinal_to_read += 1;
794 if next_offset >= end_offset {
795 return Ok(());
796 }
797
798 while _next_ordinal_to_read < 1 {
800 fidl::encoding::decode_unknown_envelope(decoder, next_offset, depth)?;
801 _next_ordinal_to_read += 1;
802 next_offset += envelope_size;
803 }
804
805 let next_out_of_line = decoder.next_out_of_line();
806 let handles_before = decoder.remaining_handles();
807 if let Some((inlined, num_bytes, num_handles)) =
808 fidl::encoding::decode_envelope_header(decoder, next_offset)?
809 {
810 let member_inline_size = <fidl::encoding::HandleType<
811 fidl::Socket,
812 { fidl::ObjectType::SOCKET.into_raw() },
813 2147483648,
814 > as fidl::encoding::TypeMarker>::inline_size(
815 decoder.context
816 );
817 if inlined != (member_inline_size <= 4) {
818 return Err(fidl::Error::InvalidInlineBitInEnvelope);
819 }
820 let inner_offset;
821 let mut inner_depth = depth.clone();
822 if inlined {
823 decoder.check_inline_envelope_padding(next_offset, member_inline_size)?;
824 inner_offset = next_offset;
825 } else {
826 inner_offset = decoder.out_of_line_offset(member_inline_size)?;
827 inner_depth.increment()?;
828 }
829 let val_ref =
830 self.server_socket.get_or_insert_with(|| fidl::new_empty!(fidl::encoding::HandleType<fidl::Socket, { fidl::ObjectType::SOCKET.into_raw() }, 2147483648>, fidl::encoding::DefaultFuchsiaResourceDialect));
831 fidl::decode!(fidl::encoding::HandleType<fidl::Socket, { fidl::ObjectType::SOCKET.into_raw() }, 2147483648>, fidl::encoding::DefaultFuchsiaResourceDialect, val_ref, decoder, inner_offset, inner_depth)?;
832 if !inlined && decoder.next_out_of_line() != next_out_of_line + (num_bytes as usize)
833 {
834 return Err(fidl::Error::InvalidNumBytesInEnvelope);
835 }
836 if handles_before != decoder.remaining_handles() + (num_handles as usize) {
837 return Err(fidl::Error::InvalidNumHandlesInEnvelope);
838 }
839 }
840
841 next_offset += envelope_size;
842 _next_ordinal_to_read += 1;
843 if next_offset >= end_offset {
844 return Ok(());
845 }
846
847 while _next_ordinal_to_read < 2 {
849 fidl::encoding::decode_unknown_envelope(decoder, next_offset, depth)?;
850 _next_ordinal_to_read += 1;
851 next_offset += envelope_size;
852 }
853
854 let next_out_of_line = decoder.next_out_of_line();
855 let handles_before = decoder.remaining_handles();
856 if let Some((inlined, num_bytes, num_handles)) =
857 fidl::encoding::decode_envelope_header(decoder, next_offset)?
858 {
859 let member_inline_size =
860 <fidl::encoding::UnboundedString as fidl::encoding::TypeMarker>::inline_size(
861 decoder.context,
862 );
863 if inlined != (member_inline_size <= 4) {
864 return Err(fidl::Error::InvalidInlineBitInEnvelope);
865 }
866 let inner_offset;
867 let mut inner_depth = depth.clone();
868 if inlined {
869 decoder.check_inline_envelope_padding(next_offset, member_inline_size)?;
870 inner_offset = next_offset;
871 } else {
872 inner_offset = decoder.out_of_line_offset(member_inline_size)?;
873 inner_depth.increment()?;
874 }
875 let val_ref = self.socket_label.get_or_insert_with(|| {
876 fidl::new_empty!(
877 fidl::encoding::UnboundedString,
878 fidl::encoding::DefaultFuchsiaResourceDialect
879 )
880 });
881 fidl::decode!(
882 fidl::encoding::UnboundedString,
883 fidl::encoding::DefaultFuchsiaResourceDialect,
884 val_ref,
885 decoder,
886 inner_offset,
887 inner_depth
888 )?;
889 if !inlined && decoder.next_out_of_line() != next_out_of_line + (num_bytes as usize)
890 {
891 return Err(fidl::Error::InvalidNumBytesInEnvelope);
892 }
893 if handles_before != decoder.remaining_handles() + (num_handles as usize) {
894 return Err(fidl::Error::InvalidNumHandlesInEnvelope);
895 }
896 }
897
898 next_offset += envelope_size;
899
900 while next_offset < end_offset {
902 _next_ordinal_to_read += 1;
903 fidl::encoding::decode_unknown_envelope(decoder, next_offset, depth)?;
904 next_offset += envelope_size;
905 }
906
907 Ok(())
908 }
909 }
910}