fidl_fidl_clientsuite/
fidl_fidl_clientsuite.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::client::QueryResponseFut;
8use fidl::encoding::{MessageBufFor, ProxyChannelBox, ResourceDialect};
9use fidl::endpoints::{ControlHandle as _, Responder as _};
10pub use fidl_fidl_clientsuite_common::*;
11use futures::future::{self, MaybeDone, TryFutureExt};
12use zx_status;
13
14#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
15pub struct RunnerCallFlexibleOneWayRequest {
16    pub target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
17}
18
19impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
20    for RunnerCallFlexibleOneWayRequest
21{
22}
23
24#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
25pub struct RunnerCallFlexibleTwoWayErrRequest {
26    pub target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
27}
28
29impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
30    for RunnerCallFlexibleTwoWayErrRequest
31{
32}
33
34#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
35pub struct RunnerCallFlexibleTwoWayFieldsErrRequest {
36    pub target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
37}
38
39impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
40    for RunnerCallFlexibleTwoWayFieldsErrRequest
41{
42}
43
44#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
45pub struct RunnerCallFlexibleTwoWayFieldsRequest {
46    pub target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
47}
48
49impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
50    for RunnerCallFlexibleTwoWayFieldsRequest
51{
52}
53
54#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
55pub struct RunnerCallFlexibleTwoWayRequest {
56    pub target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
57}
58
59impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
60    for RunnerCallFlexibleTwoWayRequest
61{
62}
63
64#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
65pub struct RunnerCallOneWayNoRequestRequest {
66    pub target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
67}
68
69impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
70    for RunnerCallOneWayNoRequestRequest
71{
72}
73
74#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
75pub struct RunnerCallOneWayStructRequestRequest {
76    pub target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
77    pub request: NonEmptyPayload,
78}
79
80impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
81    for RunnerCallOneWayStructRequestRequest
82{
83}
84
85#[derive(Debug, PartialEq)]
86pub struct RunnerCallOneWayTableRequestRequest {
87    pub target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
88    pub request: TablePayload,
89}
90
91impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
92    for RunnerCallOneWayTableRequestRequest
93{
94}
95
96#[derive(Debug, PartialEq)]
97pub struct RunnerCallOneWayUnionRequestRequest {
98    pub target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
99    pub request: UnionPayload,
100}
101
102impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
103    for RunnerCallOneWayUnionRequestRequest
104{
105}
106
107#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
108pub struct RunnerCallStrictOneWayRequest {
109    pub target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
110}
111
112impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
113    for RunnerCallStrictOneWayRequest
114{
115}
116
117#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
118pub struct RunnerCallStrictTwoWayErrRequest {
119    pub target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
120}
121
122impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
123    for RunnerCallStrictTwoWayErrRequest
124{
125}
126
127#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
128pub struct RunnerCallStrictTwoWayFieldsErrRequest {
129    pub target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
130}
131
132impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
133    for RunnerCallStrictTwoWayFieldsErrRequest
134{
135}
136
137#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
138pub struct RunnerCallStrictTwoWayFieldsRequest {
139    pub target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
140}
141
142impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
143    for RunnerCallStrictTwoWayFieldsRequest
144{
145}
146
147#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
148pub struct RunnerCallStrictTwoWayRequest {
149    pub target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
150}
151
152impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
153    for RunnerCallStrictTwoWayRequest
154{
155}
156
157#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
158pub struct RunnerCallTwoWayNoPayloadRequest {
159    pub target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
160}
161
162impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
163    for RunnerCallTwoWayNoPayloadRequest
164{
165}
166
167#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
168pub struct RunnerCallTwoWayStructPayloadErrRequest {
169    pub target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
170}
171
172impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
173    for RunnerCallTwoWayStructPayloadErrRequest
174{
175}
176
177#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
178pub struct RunnerCallTwoWayStructPayloadRequest {
179    pub target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
180}
181
182impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
183    for RunnerCallTwoWayStructPayloadRequest
184{
185}
186
187#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
188pub struct RunnerCallTwoWayStructRequestRequest {
189    pub target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
190    pub request: NonEmptyPayload,
191}
192
193impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
194    for RunnerCallTwoWayStructRequestRequest
195{
196}
197
198#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
199pub struct RunnerCallTwoWayTablePayloadRequest {
200    pub target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
201}
202
203impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
204    for RunnerCallTwoWayTablePayloadRequest
205{
206}
207
208#[derive(Debug, PartialEq)]
209pub struct RunnerCallTwoWayTableRequestRequest {
210    pub target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
211    pub request: TablePayload,
212}
213
214impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
215    for RunnerCallTwoWayTableRequestRequest
216{
217}
218
219#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
220pub struct RunnerCallTwoWayUnionPayloadRequest {
221    pub target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
222}
223
224impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
225    for RunnerCallTwoWayUnionPayloadRequest
226{
227}
228
229#[derive(Debug, PartialEq)]
230pub struct RunnerCallTwoWayUnionRequestRequest {
231    pub target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
232    pub request: UnionPayload,
233}
234
235impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
236    for RunnerCallTwoWayUnionRequestRequest
237{
238}
239
240#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
241pub struct RunnerReceiveAjarEventsRequest {
242    pub target: fidl::endpoints::ClientEnd<AjarTargetMarker>,
243    pub reporter: fidl::endpoints::ClientEnd<AjarTargetEventReporterMarker>,
244}
245
246impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
247    for RunnerReceiveAjarEventsRequest
248{
249}
250
251#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
252pub struct RunnerReceiveClosedEventsRequest {
253    pub target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
254    pub reporter: fidl::endpoints::ClientEnd<ClosedTargetEventReporterMarker>,
255}
256
257impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
258    for RunnerReceiveClosedEventsRequest
259{
260}
261
262#[derive(Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
263pub struct RunnerReceiveOpenEventsRequest {
264    pub target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
265    pub reporter: fidl::endpoints::ClientEnd<OpenTargetEventReporterMarker>,
266}
267
268impl fidl::Standalone<fidl::encoding::DefaultFuchsiaResourceDialect>
269    for RunnerReceiveOpenEventsRequest
270{
271}
272
273#[derive(Debug, Copy, Clone, Eq, PartialEq, Ord, PartialOrd, Hash)]
274pub struct AjarTargetMarker;
275
276impl fidl::endpoints::ProtocolMarker for AjarTargetMarker {
277    type Proxy = AjarTargetProxy;
278    type RequestStream = AjarTargetRequestStream;
279    #[cfg(target_os = "fuchsia")]
280    type SynchronousProxy = AjarTargetSynchronousProxy;
281
282    const DEBUG_NAME: &'static str = "(anonymous) AjarTarget";
283}
284
285pub trait AjarTargetProxyInterface: Send + Sync {}
286#[derive(Debug)]
287#[cfg(target_os = "fuchsia")]
288pub struct AjarTargetSynchronousProxy {
289    client: fidl::client::sync::Client,
290}
291
292#[cfg(target_os = "fuchsia")]
293impl fidl::endpoints::SynchronousProxy for AjarTargetSynchronousProxy {
294    type Proxy = AjarTargetProxy;
295    type Protocol = AjarTargetMarker;
296
297    fn from_channel(inner: fidl::Channel) -> Self {
298        Self::new(inner)
299    }
300
301    fn into_channel(self) -> fidl::Channel {
302        self.client.into_channel()
303    }
304
305    fn as_channel(&self) -> &fidl::Channel {
306        self.client.as_channel()
307    }
308}
309
310#[cfg(target_os = "fuchsia")]
311impl AjarTargetSynchronousProxy {
312    pub fn new(channel: fidl::Channel) -> Self {
313        let protocol_name = <AjarTargetMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME;
314        Self { client: fidl::client::sync::Client::new(channel, protocol_name) }
315    }
316
317    pub fn into_channel(self) -> fidl::Channel {
318        self.client.into_channel()
319    }
320
321    /// Waits until an event arrives and returns it. It is safe for other
322    /// threads to make concurrent requests while waiting for an event.
323    pub fn wait_for_event(
324        &self,
325        deadline: zx::MonotonicInstant,
326    ) -> Result<AjarTargetEvent, fidl::Error> {
327        AjarTargetEvent::decode(self.client.wait_for_event(deadline)?)
328    }
329}
330
331#[cfg(target_os = "fuchsia")]
332impl From<AjarTargetSynchronousProxy> for zx::Handle {
333    fn from(value: AjarTargetSynchronousProxy) -> Self {
334        value.into_channel().into()
335    }
336}
337
338#[cfg(target_os = "fuchsia")]
339impl From<fidl::Channel> for AjarTargetSynchronousProxy {
340    fn from(value: fidl::Channel) -> Self {
341        Self::new(value)
342    }
343}
344
345#[derive(Debug, Clone)]
346pub struct AjarTargetProxy {
347    client: fidl::client::Client<fidl::encoding::DefaultFuchsiaResourceDialect>,
348}
349
350impl fidl::endpoints::Proxy for AjarTargetProxy {
351    type Protocol = AjarTargetMarker;
352
353    fn from_channel(inner: ::fidl::AsyncChannel) -> Self {
354        Self::new(inner)
355    }
356
357    fn into_channel(self) -> Result<::fidl::AsyncChannel, Self> {
358        self.client.into_channel().map_err(|client| Self { client })
359    }
360
361    fn as_channel(&self) -> &::fidl::AsyncChannel {
362        self.client.as_channel()
363    }
364}
365
366impl AjarTargetProxy {
367    /// Create a new Proxy for fidl.clientsuite/AjarTarget.
368    pub fn new(channel: ::fidl::AsyncChannel) -> Self {
369        let protocol_name = <AjarTargetMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME;
370        Self { client: fidl::client::Client::new(channel, protocol_name) }
371    }
372
373    /// Get a Stream of events from the remote end of the protocol.
374    ///
375    /// # Panics
376    ///
377    /// Panics if the event stream was already taken.
378    pub fn take_event_stream(&self) -> AjarTargetEventStream {
379        AjarTargetEventStream { event_receiver: self.client.take_event_receiver() }
380    }
381}
382
383impl AjarTargetProxyInterface for AjarTargetProxy {}
384
385pub struct AjarTargetEventStream {
386    event_receiver: fidl::client::EventReceiver<fidl::encoding::DefaultFuchsiaResourceDialect>,
387}
388
389impl std::marker::Unpin for AjarTargetEventStream {}
390
391impl futures::stream::FusedStream for AjarTargetEventStream {
392    fn is_terminated(&self) -> bool {
393        self.event_receiver.is_terminated()
394    }
395}
396
397impl futures::Stream for AjarTargetEventStream {
398    type Item = Result<AjarTargetEvent, fidl::Error>;
399
400    fn poll_next(
401        mut self: std::pin::Pin<&mut Self>,
402        cx: &mut std::task::Context<'_>,
403    ) -> std::task::Poll<Option<Self::Item>> {
404        match futures::ready!(futures::stream::StreamExt::poll_next_unpin(
405            &mut self.event_receiver,
406            cx
407        )?) {
408            Some(buf) => std::task::Poll::Ready(Some(AjarTargetEvent::decode(buf))),
409            None => std::task::Poll::Ready(None),
410        }
411    }
412}
413
414#[derive(Debug)]
415pub enum AjarTargetEvent {
416    #[non_exhaustive]
417    _UnknownEvent {
418        /// Ordinal of the event that was sent.
419        ordinal: u64,
420    },
421}
422
423impl AjarTargetEvent {
424    /// Decodes a message buffer as a [`AjarTargetEvent`].
425    fn decode(
426        mut buf: <fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc,
427    ) -> Result<AjarTargetEvent, fidl::Error> {
428        let (bytes, _handles) = buf.split_mut();
429        let (tx_header, _body_bytes) = fidl::encoding::decode_transaction_header(bytes)?;
430        debug_assert_eq!(tx_header.tx_id, 0);
431        match tx_header.ordinal {
432            _ if tx_header.dynamic_flags().contains(fidl::encoding::DynamicFlags::FLEXIBLE) => {
433                Ok(AjarTargetEvent::_UnknownEvent { ordinal: tx_header.ordinal })
434            }
435            _ => Err(fidl::Error::UnknownOrdinal {
436                ordinal: tx_header.ordinal,
437                protocol_name: <AjarTargetMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME,
438            }),
439        }
440    }
441}
442
443/// A Stream of incoming requests for fidl.clientsuite/AjarTarget.
444pub struct AjarTargetRequestStream {
445    inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
446    is_terminated: bool,
447}
448
449impl std::marker::Unpin for AjarTargetRequestStream {}
450
451impl futures::stream::FusedStream for AjarTargetRequestStream {
452    fn is_terminated(&self) -> bool {
453        self.is_terminated
454    }
455}
456
457impl fidl::endpoints::RequestStream for AjarTargetRequestStream {
458    type Protocol = AjarTargetMarker;
459    type ControlHandle = AjarTargetControlHandle;
460
461    fn from_channel(channel: ::fidl::AsyncChannel) -> Self {
462        Self { inner: std::sync::Arc::new(fidl::ServeInner::new(channel)), is_terminated: false }
463    }
464
465    fn control_handle(&self) -> Self::ControlHandle {
466        AjarTargetControlHandle { inner: self.inner.clone() }
467    }
468
469    fn into_inner(
470        self,
471    ) -> (::std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>, bool)
472    {
473        (self.inner, self.is_terminated)
474    }
475
476    fn from_inner(
477        inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
478        is_terminated: bool,
479    ) -> Self {
480        Self { inner, is_terminated }
481    }
482}
483
484impl futures::Stream for AjarTargetRequestStream {
485    type Item = Result<AjarTargetRequest, fidl::Error>;
486
487    fn poll_next(
488        mut self: std::pin::Pin<&mut Self>,
489        cx: &mut std::task::Context<'_>,
490    ) -> std::task::Poll<Option<Self::Item>> {
491        let this = &mut *self;
492        if this.inner.check_shutdown(cx) {
493            this.is_terminated = true;
494            return std::task::Poll::Ready(None);
495        }
496        if this.is_terminated {
497            panic!("polled AjarTargetRequestStream after completion");
498        }
499        fidl::encoding::with_tls_decode_buf::<_, fidl::encoding::DefaultFuchsiaResourceDialect>(
500            |bytes, handles| {
501                match this.inner.channel().read_etc(cx, bytes, handles) {
502                    std::task::Poll::Ready(Ok(())) => {}
503                    std::task::Poll::Pending => return std::task::Poll::Pending,
504                    std::task::Poll::Ready(Err(zx_status::Status::PEER_CLOSED)) => {
505                        this.is_terminated = true;
506                        return std::task::Poll::Ready(None);
507                    }
508                    std::task::Poll::Ready(Err(e)) => {
509                        return std::task::Poll::Ready(Some(Err(fidl::Error::ServerRequestRead(
510                            e.into(),
511                        ))))
512                    }
513                }
514
515                // A message has been received from the channel
516                let (header, _body_bytes) = fidl::encoding::decode_transaction_header(bytes)?;
517
518                std::task::Poll::Ready(Some(match header.ordinal {
519                    _ if header.tx_id == 0
520                        && header
521                            .dynamic_flags()
522                            .contains(fidl::encoding::DynamicFlags::FLEXIBLE) =>
523                    {
524                        Ok(AjarTargetRequest::_UnknownMethod {
525                            ordinal: header.ordinal,
526                            control_handle: AjarTargetControlHandle { inner: this.inner.clone() },
527                        })
528                    }
529                    _ => Err(fidl::Error::UnknownOrdinal {
530                        ordinal: header.ordinal,
531                        protocol_name:
532                            <AjarTargetMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME,
533                    }),
534                }))
535            },
536        )
537    }
538}
539
540#[derive(Debug)]
541pub enum AjarTargetRequest {
542    /// An interaction was received which does not match any known method.
543    #[non_exhaustive]
544    _UnknownMethod {
545        /// Ordinal of the method that was called.
546        ordinal: u64,
547        control_handle: AjarTargetControlHandle,
548    },
549}
550
551impl AjarTargetRequest {
552    /// Name of the method defined in FIDL
553    pub fn method_name(&self) -> &'static str {
554        match *self {
555            AjarTargetRequest::_UnknownMethod { .. } => "unknown one-way method",
556        }
557    }
558}
559
560#[derive(Debug, Clone)]
561pub struct AjarTargetControlHandle {
562    inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
563}
564
565impl fidl::endpoints::ControlHandle for AjarTargetControlHandle {
566    fn shutdown(&self) {
567        self.inner.shutdown()
568    }
569    fn shutdown_with_epitaph(&self, status: zx_status::Status) {
570        self.inner.shutdown_with_epitaph(status)
571    }
572
573    fn is_closed(&self) -> bool {
574        self.inner.channel().is_closed()
575    }
576    fn on_closed(&self) -> fidl::OnSignalsRef<'_> {
577        self.inner.channel().on_closed()
578    }
579
580    #[cfg(target_os = "fuchsia")]
581    fn signal_peer(
582        &self,
583        clear_mask: zx::Signals,
584        set_mask: zx::Signals,
585    ) -> Result<(), zx_status::Status> {
586        use fidl::Peered;
587        self.inner.channel().signal_peer(clear_mask, set_mask)
588    }
589}
590
591impl AjarTargetControlHandle {}
592
593#[derive(Debug, Copy, Clone, Eq, PartialEq, Ord, PartialOrd, Hash)]
594pub struct AjarTargetEventReporterMarker;
595
596impl fidl::endpoints::ProtocolMarker for AjarTargetEventReporterMarker {
597    type Proxy = AjarTargetEventReporterProxy;
598    type RequestStream = AjarTargetEventReporterRequestStream;
599    #[cfg(target_os = "fuchsia")]
600    type SynchronousProxy = AjarTargetEventReporterSynchronousProxy;
601
602    const DEBUG_NAME: &'static str = "(anonymous) AjarTargetEventReporter";
603}
604
605pub trait AjarTargetEventReporterProxyInterface: Send + Sync {
606    fn r#report_event(&self, payload: &AjarTargetEventReport) -> Result<(), fidl::Error>;
607}
608#[derive(Debug)]
609#[cfg(target_os = "fuchsia")]
610pub struct AjarTargetEventReporterSynchronousProxy {
611    client: fidl::client::sync::Client,
612}
613
614#[cfg(target_os = "fuchsia")]
615impl fidl::endpoints::SynchronousProxy for AjarTargetEventReporterSynchronousProxy {
616    type Proxy = AjarTargetEventReporterProxy;
617    type Protocol = AjarTargetEventReporterMarker;
618
619    fn from_channel(inner: fidl::Channel) -> Self {
620        Self::new(inner)
621    }
622
623    fn into_channel(self) -> fidl::Channel {
624        self.client.into_channel()
625    }
626
627    fn as_channel(&self) -> &fidl::Channel {
628        self.client.as_channel()
629    }
630}
631
632#[cfg(target_os = "fuchsia")]
633impl AjarTargetEventReporterSynchronousProxy {
634    pub fn new(channel: fidl::Channel) -> Self {
635        let protocol_name =
636            <AjarTargetEventReporterMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME;
637        Self { client: fidl::client::sync::Client::new(channel, protocol_name) }
638    }
639
640    pub fn into_channel(self) -> fidl::Channel {
641        self.client.into_channel()
642    }
643
644    /// Waits until an event arrives and returns it. It is safe for other
645    /// threads to make concurrent requests while waiting for an event.
646    pub fn wait_for_event(
647        &self,
648        deadline: zx::MonotonicInstant,
649    ) -> Result<AjarTargetEventReporterEvent, fidl::Error> {
650        AjarTargetEventReporterEvent::decode(self.client.wait_for_event(deadline)?)
651    }
652
653    pub fn r#report_event(&self, mut payload: &AjarTargetEventReport) -> Result<(), fidl::Error> {
654        self.client.send::<AjarTargetEventReport>(
655            payload,
656            0x477b93390be99238,
657            fidl::encoding::DynamicFlags::empty(),
658        )
659    }
660}
661
662#[cfg(target_os = "fuchsia")]
663impl From<AjarTargetEventReporterSynchronousProxy> for zx::Handle {
664    fn from(value: AjarTargetEventReporterSynchronousProxy) -> Self {
665        value.into_channel().into()
666    }
667}
668
669#[cfg(target_os = "fuchsia")]
670impl From<fidl::Channel> for AjarTargetEventReporterSynchronousProxy {
671    fn from(value: fidl::Channel) -> Self {
672        Self::new(value)
673    }
674}
675
676#[derive(Debug, Clone)]
677pub struct AjarTargetEventReporterProxy {
678    client: fidl::client::Client<fidl::encoding::DefaultFuchsiaResourceDialect>,
679}
680
681impl fidl::endpoints::Proxy for AjarTargetEventReporterProxy {
682    type Protocol = AjarTargetEventReporterMarker;
683
684    fn from_channel(inner: ::fidl::AsyncChannel) -> Self {
685        Self::new(inner)
686    }
687
688    fn into_channel(self) -> Result<::fidl::AsyncChannel, Self> {
689        self.client.into_channel().map_err(|client| Self { client })
690    }
691
692    fn as_channel(&self) -> &::fidl::AsyncChannel {
693        self.client.as_channel()
694    }
695}
696
697impl AjarTargetEventReporterProxy {
698    /// Create a new Proxy for fidl.clientsuite/AjarTargetEventReporter.
699    pub fn new(channel: ::fidl::AsyncChannel) -> Self {
700        let protocol_name =
701            <AjarTargetEventReporterMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME;
702        Self { client: fidl::client::Client::new(channel, protocol_name) }
703    }
704
705    /// Get a Stream of events from the remote end of the protocol.
706    ///
707    /// # Panics
708    ///
709    /// Panics if the event stream was already taken.
710    pub fn take_event_stream(&self) -> AjarTargetEventReporterEventStream {
711        AjarTargetEventReporterEventStream { event_receiver: self.client.take_event_receiver() }
712    }
713
714    pub fn r#report_event(&self, mut payload: &AjarTargetEventReport) -> Result<(), fidl::Error> {
715        AjarTargetEventReporterProxyInterface::r#report_event(self, payload)
716    }
717}
718
719impl AjarTargetEventReporterProxyInterface for AjarTargetEventReporterProxy {
720    fn r#report_event(&self, mut payload: &AjarTargetEventReport) -> Result<(), fidl::Error> {
721        self.client.send::<AjarTargetEventReport>(
722            payload,
723            0x477b93390be99238,
724            fidl::encoding::DynamicFlags::empty(),
725        )
726    }
727}
728
729pub struct AjarTargetEventReporterEventStream {
730    event_receiver: fidl::client::EventReceiver<fidl::encoding::DefaultFuchsiaResourceDialect>,
731}
732
733impl std::marker::Unpin for AjarTargetEventReporterEventStream {}
734
735impl futures::stream::FusedStream for AjarTargetEventReporterEventStream {
736    fn is_terminated(&self) -> bool {
737        self.event_receiver.is_terminated()
738    }
739}
740
741impl futures::Stream for AjarTargetEventReporterEventStream {
742    type Item = Result<AjarTargetEventReporterEvent, fidl::Error>;
743
744    fn poll_next(
745        mut self: std::pin::Pin<&mut Self>,
746        cx: &mut std::task::Context<'_>,
747    ) -> std::task::Poll<Option<Self::Item>> {
748        match futures::ready!(futures::stream::StreamExt::poll_next_unpin(
749            &mut self.event_receiver,
750            cx
751        )?) {
752            Some(buf) => std::task::Poll::Ready(Some(AjarTargetEventReporterEvent::decode(buf))),
753            None => std::task::Poll::Ready(None),
754        }
755    }
756}
757
758#[derive(Debug)]
759pub enum AjarTargetEventReporterEvent {}
760
761impl AjarTargetEventReporterEvent {
762    /// Decodes a message buffer as a [`AjarTargetEventReporterEvent`].
763    fn decode(
764        mut buf: <fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc,
765    ) -> Result<AjarTargetEventReporterEvent, fidl::Error> {
766        let (bytes, _handles) = buf.split_mut();
767        let (tx_header, _body_bytes) = fidl::encoding::decode_transaction_header(bytes)?;
768        debug_assert_eq!(tx_header.tx_id, 0);
769        match tx_header.ordinal {
770            _ => Err(fidl::Error::UnknownOrdinal {
771                ordinal: tx_header.ordinal,
772                protocol_name:
773                    <AjarTargetEventReporterMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME,
774            }),
775        }
776    }
777}
778
779/// A Stream of incoming requests for fidl.clientsuite/AjarTargetEventReporter.
780pub struct AjarTargetEventReporterRequestStream {
781    inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
782    is_terminated: bool,
783}
784
785impl std::marker::Unpin for AjarTargetEventReporterRequestStream {}
786
787impl futures::stream::FusedStream for AjarTargetEventReporterRequestStream {
788    fn is_terminated(&self) -> bool {
789        self.is_terminated
790    }
791}
792
793impl fidl::endpoints::RequestStream for AjarTargetEventReporterRequestStream {
794    type Protocol = AjarTargetEventReporterMarker;
795    type ControlHandle = AjarTargetEventReporterControlHandle;
796
797    fn from_channel(channel: ::fidl::AsyncChannel) -> Self {
798        Self { inner: std::sync::Arc::new(fidl::ServeInner::new(channel)), is_terminated: false }
799    }
800
801    fn control_handle(&self) -> Self::ControlHandle {
802        AjarTargetEventReporterControlHandle { inner: self.inner.clone() }
803    }
804
805    fn into_inner(
806        self,
807    ) -> (::std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>, bool)
808    {
809        (self.inner, self.is_terminated)
810    }
811
812    fn from_inner(
813        inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
814        is_terminated: bool,
815    ) -> Self {
816        Self { inner, is_terminated }
817    }
818}
819
820impl futures::Stream for AjarTargetEventReporterRequestStream {
821    type Item = Result<AjarTargetEventReporterRequest, fidl::Error>;
822
823    fn poll_next(
824        mut self: std::pin::Pin<&mut Self>,
825        cx: &mut std::task::Context<'_>,
826    ) -> std::task::Poll<Option<Self::Item>> {
827        let this = &mut *self;
828        if this.inner.check_shutdown(cx) {
829            this.is_terminated = true;
830            return std::task::Poll::Ready(None);
831        }
832        if this.is_terminated {
833            panic!("polled AjarTargetEventReporterRequestStream after completion");
834        }
835        fidl::encoding::with_tls_decode_buf::<_, fidl::encoding::DefaultFuchsiaResourceDialect>(
836            |bytes, handles| {
837                match this.inner.channel().read_etc(cx, bytes, handles) {
838                    std::task::Poll::Ready(Ok(())) => {}
839                    std::task::Poll::Pending => return std::task::Poll::Pending,
840                    std::task::Poll::Ready(Err(zx_status::Status::PEER_CLOSED)) => {
841                        this.is_terminated = true;
842                        return std::task::Poll::Ready(None);
843                    }
844                    std::task::Poll::Ready(Err(e)) => {
845                        return std::task::Poll::Ready(Some(Err(fidl::Error::ServerRequestRead(
846                            e.into(),
847                        ))))
848                    }
849                }
850
851                // A message has been received from the channel
852                let (header, _body_bytes) = fidl::encoding::decode_transaction_header(bytes)?;
853
854                std::task::Poll::Ready(Some(match header.ordinal {
855                0x477b93390be99238 => {
856                    header.validate_request_tx_id(fidl::MethodType::OneWay)?;
857                    let mut req = fidl::new_empty!(AjarTargetEventReport, fidl::encoding::DefaultFuchsiaResourceDialect);
858                    fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<AjarTargetEventReport>(&header, _body_bytes, handles, &mut req)?;
859                    let control_handle = AjarTargetEventReporterControlHandle {
860                        inner: this.inner.clone(),
861                    };
862                    Ok(AjarTargetEventReporterRequest::ReportEvent {payload: req,
863                        control_handle,
864                    })
865                }
866                _ => Err(fidl::Error::UnknownOrdinal {
867                    ordinal: header.ordinal,
868                    protocol_name: <AjarTargetEventReporterMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME,
869                }),
870            }))
871            },
872        )
873    }
874}
875
876#[derive(Debug)]
877pub enum AjarTargetEventReporterRequest {
878    ReportEvent {
879        payload: AjarTargetEventReport,
880        control_handle: AjarTargetEventReporterControlHandle,
881    },
882}
883
884impl AjarTargetEventReporterRequest {
885    #[allow(irrefutable_let_patterns)]
886    pub fn into_report_event(
887        self,
888    ) -> Option<(AjarTargetEventReport, AjarTargetEventReporterControlHandle)> {
889        if let AjarTargetEventReporterRequest::ReportEvent { payload, control_handle } = self {
890            Some((payload, control_handle))
891        } else {
892            None
893        }
894    }
895
896    /// Name of the method defined in FIDL
897    pub fn method_name(&self) -> &'static str {
898        match *self {
899            AjarTargetEventReporterRequest::ReportEvent { .. } => "report_event",
900        }
901    }
902}
903
904#[derive(Debug, Clone)]
905pub struct AjarTargetEventReporterControlHandle {
906    inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
907}
908
909impl fidl::endpoints::ControlHandle for AjarTargetEventReporterControlHandle {
910    fn shutdown(&self) {
911        self.inner.shutdown()
912    }
913    fn shutdown_with_epitaph(&self, status: zx_status::Status) {
914        self.inner.shutdown_with_epitaph(status)
915    }
916
917    fn is_closed(&self) -> bool {
918        self.inner.channel().is_closed()
919    }
920    fn on_closed(&self) -> fidl::OnSignalsRef<'_> {
921        self.inner.channel().on_closed()
922    }
923
924    #[cfg(target_os = "fuchsia")]
925    fn signal_peer(
926        &self,
927        clear_mask: zx::Signals,
928        set_mask: zx::Signals,
929    ) -> Result<(), zx_status::Status> {
930        use fidl::Peered;
931        self.inner.channel().signal_peer(clear_mask, set_mask)
932    }
933}
934
935impl AjarTargetEventReporterControlHandle {}
936
937#[derive(Debug, Copy, Clone, Eq, PartialEq, Ord, PartialOrd, Hash)]
938pub struct ClosedTargetMarker;
939
940impl fidl::endpoints::ProtocolMarker for ClosedTargetMarker {
941    type Proxy = ClosedTargetProxy;
942    type RequestStream = ClosedTargetRequestStream;
943    #[cfg(target_os = "fuchsia")]
944    type SynchronousProxy = ClosedTargetSynchronousProxy;
945
946    const DEBUG_NAME: &'static str = "(anonymous) ClosedTarget";
947}
948pub type ClosedTargetTwoWayStructPayloadErrResult = Result<i32, i32>;
949
950pub trait ClosedTargetProxyInterface: Send + Sync {
951    type TwoWayNoPayloadResponseFut: std::future::Future<Output = Result<(), fidl::Error>> + Send;
952    fn r#two_way_no_payload(&self) -> Self::TwoWayNoPayloadResponseFut;
953    type TwoWayStructPayloadResponseFut: std::future::Future<Output = Result<i32, fidl::Error>>
954        + Send;
955    fn r#two_way_struct_payload(&self) -> Self::TwoWayStructPayloadResponseFut;
956    type TwoWayTablePayloadResponseFut: std::future::Future<Output = Result<TablePayload, fidl::Error>>
957        + Send;
958    fn r#two_way_table_payload(&self) -> Self::TwoWayTablePayloadResponseFut;
959    type TwoWayUnionPayloadResponseFut: std::future::Future<Output = Result<UnionPayload, fidl::Error>>
960        + Send;
961    fn r#two_way_union_payload(&self) -> Self::TwoWayUnionPayloadResponseFut;
962    type TwoWayStructPayloadErrResponseFut: std::future::Future<Output = Result<ClosedTargetTwoWayStructPayloadErrResult, fidl::Error>>
963        + Send;
964    fn r#two_way_struct_payload_err(&self) -> Self::TwoWayStructPayloadErrResponseFut;
965    type TwoWayStructRequestResponseFut: std::future::Future<Output = Result<(), fidl::Error>>
966        + Send;
967    fn r#two_way_struct_request(&self, some_field: i32) -> Self::TwoWayStructRequestResponseFut;
968    type TwoWayTableRequestResponseFut: std::future::Future<Output = Result<(), fidl::Error>> + Send;
969    fn r#two_way_table_request(
970        &self,
971        payload: &TablePayload,
972    ) -> Self::TwoWayTableRequestResponseFut;
973    type TwoWayUnionRequestResponseFut: std::future::Future<Output = Result<(), fidl::Error>> + Send;
974    fn r#two_way_union_request(
975        &self,
976        payload: &UnionPayload,
977    ) -> Self::TwoWayUnionRequestResponseFut;
978    fn r#one_way_no_request(&self) -> Result<(), fidl::Error>;
979    fn r#one_way_struct_request(&self, some_field: i32) -> Result<(), fidl::Error>;
980    fn r#one_way_table_request(&self, payload: &TablePayload) -> Result<(), fidl::Error>;
981    fn r#one_way_union_request(&self, payload: &UnionPayload) -> Result<(), fidl::Error>;
982}
983#[derive(Debug)]
984#[cfg(target_os = "fuchsia")]
985pub struct ClosedTargetSynchronousProxy {
986    client: fidl::client::sync::Client,
987}
988
989#[cfg(target_os = "fuchsia")]
990impl fidl::endpoints::SynchronousProxy for ClosedTargetSynchronousProxy {
991    type Proxy = ClosedTargetProxy;
992    type Protocol = ClosedTargetMarker;
993
994    fn from_channel(inner: fidl::Channel) -> Self {
995        Self::new(inner)
996    }
997
998    fn into_channel(self) -> fidl::Channel {
999        self.client.into_channel()
1000    }
1001
1002    fn as_channel(&self) -> &fidl::Channel {
1003        self.client.as_channel()
1004    }
1005}
1006
1007#[cfg(target_os = "fuchsia")]
1008impl ClosedTargetSynchronousProxy {
1009    pub fn new(channel: fidl::Channel) -> Self {
1010        let protocol_name = <ClosedTargetMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME;
1011        Self { client: fidl::client::sync::Client::new(channel, protocol_name) }
1012    }
1013
1014    pub fn into_channel(self) -> fidl::Channel {
1015        self.client.into_channel()
1016    }
1017
1018    /// Waits until an event arrives and returns it. It is safe for other
1019    /// threads to make concurrent requests while waiting for an event.
1020    pub fn wait_for_event(
1021        &self,
1022        deadline: zx::MonotonicInstant,
1023    ) -> Result<ClosedTargetEvent, fidl::Error> {
1024        ClosedTargetEvent::decode(self.client.wait_for_event(deadline)?)
1025    }
1026
1027    pub fn r#two_way_no_payload(
1028        &self,
1029        ___deadline: zx::MonotonicInstant,
1030    ) -> Result<(), fidl::Error> {
1031        let _response =
1032            self.client.send_query::<fidl::encoding::EmptyPayload, fidl::encoding::EmptyPayload>(
1033                (),
1034                0x7a722961424c1720,
1035                fidl::encoding::DynamicFlags::empty(),
1036                ___deadline,
1037            )?;
1038        Ok(_response)
1039    }
1040
1041    pub fn r#two_way_struct_payload(
1042        &self,
1043        ___deadline: zx::MonotonicInstant,
1044    ) -> Result<i32, fidl::Error> {
1045        let _response = self.client.send_query::<fidl::encoding::EmptyPayload, NonEmptyPayload>(
1046            (),
1047            0x3a402118bad781bd,
1048            fidl::encoding::DynamicFlags::empty(),
1049            ___deadline,
1050        )?;
1051        Ok(_response.some_field)
1052    }
1053
1054    pub fn r#two_way_table_payload(
1055        &self,
1056        ___deadline: zx::MonotonicInstant,
1057    ) -> Result<TablePayload, fidl::Error> {
1058        let _response = self.client.send_query::<fidl::encoding::EmptyPayload, TablePayload>(
1059            (),
1060            0x53be101c241c66bc,
1061            fidl::encoding::DynamicFlags::empty(),
1062            ___deadline,
1063        )?;
1064        Ok(_response)
1065    }
1066
1067    pub fn r#two_way_union_payload(
1068        &self,
1069        ___deadline: zx::MonotonicInstant,
1070    ) -> Result<UnionPayload, fidl::Error> {
1071        let _response = self.client.send_query::<fidl::encoding::EmptyPayload, UnionPayload>(
1072            (),
1073            0x1ff7f745ab608f8c,
1074            fidl::encoding::DynamicFlags::empty(),
1075            ___deadline,
1076        )?;
1077        Ok(_response)
1078    }
1079
1080    pub fn r#two_way_struct_payload_err(
1081        &self,
1082        ___deadline: zx::MonotonicInstant,
1083    ) -> Result<ClosedTargetTwoWayStructPayloadErrResult, fidl::Error> {
1084        let _response = self.client.send_query::<
1085            fidl::encoding::EmptyPayload,
1086            fidl::encoding::ResultType<NonEmptyPayload, i32>,
1087        >(
1088            (),
1089            0x62b4861c443bbc0b,
1090            fidl::encoding::DynamicFlags::empty(),
1091            ___deadline,
1092        )?;
1093        Ok(_response.map(|x| x.some_field))
1094    }
1095
1096    pub fn r#two_way_struct_request(
1097        &self,
1098        mut some_field: i32,
1099        ___deadline: zx::MonotonicInstant,
1100    ) -> Result<(), fidl::Error> {
1101        let _response = self.client.send_query::<NonEmptyPayload, fidl::encoding::EmptyPayload>(
1102            (some_field,),
1103            0x4ff77b4a913be5b6,
1104            fidl::encoding::DynamicFlags::empty(),
1105            ___deadline,
1106        )?;
1107        Ok(_response)
1108    }
1109
1110    pub fn r#two_way_table_request(
1111        &self,
1112        mut payload: &TablePayload,
1113        ___deadline: zx::MonotonicInstant,
1114    ) -> Result<(), fidl::Error> {
1115        let _response = self.client.send_query::<TablePayload, fidl::encoding::EmptyPayload>(
1116            payload,
1117            0x3d38ad5b0f4f49cf,
1118            fidl::encoding::DynamicFlags::empty(),
1119            ___deadline,
1120        )?;
1121        Ok(_response)
1122    }
1123
1124    pub fn r#two_way_union_request(
1125        &self,
1126        mut payload: &UnionPayload,
1127        ___deadline: zx::MonotonicInstant,
1128    ) -> Result<(), fidl::Error> {
1129        let _response = self.client.send_query::<UnionPayload, fidl::encoding::EmptyPayload>(
1130            payload,
1131            0x7adb1c265a378e77,
1132            fidl::encoding::DynamicFlags::empty(),
1133            ___deadline,
1134        )?;
1135        Ok(_response)
1136    }
1137
1138    pub fn r#one_way_no_request(&self) -> Result<(), fidl::Error> {
1139        self.client.send::<fidl::encoding::EmptyPayload>(
1140            (),
1141            0xc376730a2cd8a05,
1142            fidl::encoding::DynamicFlags::empty(),
1143        )
1144    }
1145
1146    pub fn r#one_way_struct_request(&self, mut some_field: i32) -> Result<(), fidl::Error> {
1147        self.client.send::<NonEmptyPayload>(
1148            (some_field,),
1149            0x2618da6f51e0dcd2,
1150            fidl::encoding::DynamicFlags::empty(),
1151        )
1152    }
1153
1154    pub fn r#one_way_table_request(&self, mut payload: &TablePayload) -> Result<(), fidl::Error> {
1155        self.client.send::<TablePayload>(
1156            payload,
1157            0x1a4b7d32eaed401f,
1158            fidl::encoding::DynamicFlags::empty(),
1159        )
1160    }
1161
1162    pub fn r#one_way_union_request(&self, mut payload: &UnionPayload) -> Result<(), fidl::Error> {
1163        self.client.send::<UnionPayload>(
1164            payload,
1165            0x142b3cd9ea530de5,
1166            fidl::encoding::DynamicFlags::empty(),
1167        )
1168    }
1169}
1170
1171#[cfg(target_os = "fuchsia")]
1172impl From<ClosedTargetSynchronousProxy> for zx::Handle {
1173    fn from(value: ClosedTargetSynchronousProxy) -> Self {
1174        value.into_channel().into()
1175    }
1176}
1177
1178#[cfg(target_os = "fuchsia")]
1179impl From<fidl::Channel> for ClosedTargetSynchronousProxy {
1180    fn from(value: fidl::Channel) -> Self {
1181        Self::new(value)
1182    }
1183}
1184
1185#[derive(Debug, Clone)]
1186pub struct ClosedTargetProxy {
1187    client: fidl::client::Client<fidl::encoding::DefaultFuchsiaResourceDialect>,
1188}
1189
1190impl fidl::endpoints::Proxy for ClosedTargetProxy {
1191    type Protocol = ClosedTargetMarker;
1192
1193    fn from_channel(inner: ::fidl::AsyncChannel) -> Self {
1194        Self::new(inner)
1195    }
1196
1197    fn into_channel(self) -> Result<::fidl::AsyncChannel, Self> {
1198        self.client.into_channel().map_err(|client| Self { client })
1199    }
1200
1201    fn as_channel(&self) -> &::fidl::AsyncChannel {
1202        self.client.as_channel()
1203    }
1204}
1205
1206impl ClosedTargetProxy {
1207    /// Create a new Proxy for fidl.clientsuite/ClosedTarget.
1208    pub fn new(channel: ::fidl::AsyncChannel) -> Self {
1209        let protocol_name = <ClosedTargetMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME;
1210        Self { client: fidl::client::Client::new(channel, protocol_name) }
1211    }
1212
1213    /// Get a Stream of events from the remote end of the protocol.
1214    ///
1215    /// # Panics
1216    ///
1217    /// Panics if the event stream was already taken.
1218    pub fn take_event_stream(&self) -> ClosedTargetEventStream {
1219        ClosedTargetEventStream { event_receiver: self.client.take_event_receiver() }
1220    }
1221
1222    pub fn r#two_way_no_payload(
1223        &self,
1224    ) -> fidl::client::QueryResponseFut<(), fidl::encoding::DefaultFuchsiaResourceDialect> {
1225        ClosedTargetProxyInterface::r#two_way_no_payload(self)
1226    }
1227
1228    pub fn r#two_way_struct_payload(
1229        &self,
1230    ) -> fidl::client::QueryResponseFut<i32, fidl::encoding::DefaultFuchsiaResourceDialect> {
1231        ClosedTargetProxyInterface::r#two_way_struct_payload(self)
1232    }
1233
1234    pub fn r#two_way_table_payload(
1235        &self,
1236    ) -> fidl::client::QueryResponseFut<TablePayload, fidl::encoding::DefaultFuchsiaResourceDialect>
1237    {
1238        ClosedTargetProxyInterface::r#two_way_table_payload(self)
1239    }
1240
1241    pub fn r#two_way_union_payload(
1242        &self,
1243    ) -> fidl::client::QueryResponseFut<UnionPayload, fidl::encoding::DefaultFuchsiaResourceDialect>
1244    {
1245        ClosedTargetProxyInterface::r#two_way_union_payload(self)
1246    }
1247
1248    pub fn r#two_way_struct_payload_err(
1249        &self,
1250    ) -> fidl::client::QueryResponseFut<
1251        ClosedTargetTwoWayStructPayloadErrResult,
1252        fidl::encoding::DefaultFuchsiaResourceDialect,
1253    > {
1254        ClosedTargetProxyInterface::r#two_way_struct_payload_err(self)
1255    }
1256
1257    pub fn r#two_way_struct_request(
1258        &self,
1259        mut some_field: i32,
1260    ) -> fidl::client::QueryResponseFut<(), fidl::encoding::DefaultFuchsiaResourceDialect> {
1261        ClosedTargetProxyInterface::r#two_way_struct_request(self, some_field)
1262    }
1263
1264    pub fn r#two_way_table_request(
1265        &self,
1266        mut payload: &TablePayload,
1267    ) -> fidl::client::QueryResponseFut<(), fidl::encoding::DefaultFuchsiaResourceDialect> {
1268        ClosedTargetProxyInterface::r#two_way_table_request(self, payload)
1269    }
1270
1271    pub fn r#two_way_union_request(
1272        &self,
1273        mut payload: &UnionPayload,
1274    ) -> fidl::client::QueryResponseFut<(), fidl::encoding::DefaultFuchsiaResourceDialect> {
1275        ClosedTargetProxyInterface::r#two_way_union_request(self, payload)
1276    }
1277
1278    pub fn r#one_way_no_request(&self) -> Result<(), fidl::Error> {
1279        ClosedTargetProxyInterface::r#one_way_no_request(self)
1280    }
1281
1282    pub fn r#one_way_struct_request(&self, mut some_field: i32) -> Result<(), fidl::Error> {
1283        ClosedTargetProxyInterface::r#one_way_struct_request(self, some_field)
1284    }
1285
1286    pub fn r#one_way_table_request(&self, mut payload: &TablePayload) -> Result<(), fidl::Error> {
1287        ClosedTargetProxyInterface::r#one_way_table_request(self, payload)
1288    }
1289
1290    pub fn r#one_way_union_request(&self, mut payload: &UnionPayload) -> Result<(), fidl::Error> {
1291        ClosedTargetProxyInterface::r#one_way_union_request(self, payload)
1292    }
1293}
1294
1295impl ClosedTargetProxyInterface for ClosedTargetProxy {
1296    type TwoWayNoPayloadResponseFut =
1297        fidl::client::QueryResponseFut<(), fidl::encoding::DefaultFuchsiaResourceDialect>;
1298    fn r#two_way_no_payload(&self) -> Self::TwoWayNoPayloadResponseFut {
1299        fn _decode(
1300            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
1301        ) -> Result<(), fidl::Error> {
1302            let _response = fidl::client::decode_transaction_body::<
1303                fidl::encoding::EmptyPayload,
1304                fidl::encoding::DefaultFuchsiaResourceDialect,
1305                0x7a722961424c1720,
1306            >(_buf?)?;
1307            Ok(_response)
1308        }
1309        self.client.send_query_and_decode::<fidl::encoding::EmptyPayload, ()>(
1310            (),
1311            0x7a722961424c1720,
1312            fidl::encoding::DynamicFlags::empty(),
1313            _decode,
1314        )
1315    }
1316
1317    type TwoWayStructPayloadResponseFut =
1318        fidl::client::QueryResponseFut<i32, fidl::encoding::DefaultFuchsiaResourceDialect>;
1319    fn r#two_way_struct_payload(&self) -> Self::TwoWayStructPayloadResponseFut {
1320        fn _decode(
1321            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
1322        ) -> Result<i32, fidl::Error> {
1323            let _response = fidl::client::decode_transaction_body::<
1324                NonEmptyPayload,
1325                fidl::encoding::DefaultFuchsiaResourceDialect,
1326                0x3a402118bad781bd,
1327            >(_buf?)?;
1328            Ok(_response.some_field)
1329        }
1330        self.client.send_query_and_decode::<fidl::encoding::EmptyPayload, i32>(
1331            (),
1332            0x3a402118bad781bd,
1333            fidl::encoding::DynamicFlags::empty(),
1334            _decode,
1335        )
1336    }
1337
1338    type TwoWayTablePayloadResponseFut =
1339        fidl::client::QueryResponseFut<TablePayload, fidl::encoding::DefaultFuchsiaResourceDialect>;
1340    fn r#two_way_table_payload(&self) -> Self::TwoWayTablePayloadResponseFut {
1341        fn _decode(
1342            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
1343        ) -> Result<TablePayload, fidl::Error> {
1344            let _response = fidl::client::decode_transaction_body::<
1345                TablePayload,
1346                fidl::encoding::DefaultFuchsiaResourceDialect,
1347                0x53be101c241c66bc,
1348            >(_buf?)?;
1349            Ok(_response)
1350        }
1351        self.client.send_query_and_decode::<fidl::encoding::EmptyPayload, TablePayload>(
1352            (),
1353            0x53be101c241c66bc,
1354            fidl::encoding::DynamicFlags::empty(),
1355            _decode,
1356        )
1357    }
1358
1359    type TwoWayUnionPayloadResponseFut =
1360        fidl::client::QueryResponseFut<UnionPayload, fidl::encoding::DefaultFuchsiaResourceDialect>;
1361    fn r#two_way_union_payload(&self) -> Self::TwoWayUnionPayloadResponseFut {
1362        fn _decode(
1363            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
1364        ) -> Result<UnionPayload, fidl::Error> {
1365            let _response = fidl::client::decode_transaction_body::<
1366                UnionPayload,
1367                fidl::encoding::DefaultFuchsiaResourceDialect,
1368                0x1ff7f745ab608f8c,
1369            >(_buf?)?;
1370            Ok(_response)
1371        }
1372        self.client.send_query_and_decode::<fidl::encoding::EmptyPayload, UnionPayload>(
1373            (),
1374            0x1ff7f745ab608f8c,
1375            fidl::encoding::DynamicFlags::empty(),
1376            _decode,
1377        )
1378    }
1379
1380    type TwoWayStructPayloadErrResponseFut = fidl::client::QueryResponseFut<
1381        ClosedTargetTwoWayStructPayloadErrResult,
1382        fidl::encoding::DefaultFuchsiaResourceDialect,
1383    >;
1384    fn r#two_way_struct_payload_err(&self) -> Self::TwoWayStructPayloadErrResponseFut {
1385        fn _decode(
1386            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
1387        ) -> Result<ClosedTargetTwoWayStructPayloadErrResult, fidl::Error> {
1388            let _response = fidl::client::decode_transaction_body::<
1389                fidl::encoding::ResultType<NonEmptyPayload, i32>,
1390                fidl::encoding::DefaultFuchsiaResourceDialect,
1391                0x62b4861c443bbc0b,
1392            >(_buf?)?;
1393            Ok(_response.map(|x| x.some_field))
1394        }
1395        self.client.send_query_and_decode::<
1396            fidl::encoding::EmptyPayload,
1397            ClosedTargetTwoWayStructPayloadErrResult,
1398        >(
1399            (),
1400            0x62b4861c443bbc0b,
1401            fidl::encoding::DynamicFlags::empty(),
1402            _decode,
1403        )
1404    }
1405
1406    type TwoWayStructRequestResponseFut =
1407        fidl::client::QueryResponseFut<(), fidl::encoding::DefaultFuchsiaResourceDialect>;
1408    fn r#two_way_struct_request(
1409        &self,
1410        mut some_field: i32,
1411    ) -> Self::TwoWayStructRequestResponseFut {
1412        fn _decode(
1413            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
1414        ) -> Result<(), fidl::Error> {
1415            let _response = fidl::client::decode_transaction_body::<
1416                fidl::encoding::EmptyPayload,
1417                fidl::encoding::DefaultFuchsiaResourceDialect,
1418                0x4ff77b4a913be5b6,
1419            >(_buf?)?;
1420            Ok(_response)
1421        }
1422        self.client.send_query_and_decode::<NonEmptyPayload, ()>(
1423            (some_field,),
1424            0x4ff77b4a913be5b6,
1425            fidl::encoding::DynamicFlags::empty(),
1426            _decode,
1427        )
1428    }
1429
1430    type TwoWayTableRequestResponseFut =
1431        fidl::client::QueryResponseFut<(), fidl::encoding::DefaultFuchsiaResourceDialect>;
1432    fn r#two_way_table_request(
1433        &self,
1434        mut payload: &TablePayload,
1435    ) -> Self::TwoWayTableRequestResponseFut {
1436        fn _decode(
1437            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
1438        ) -> Result<(), fidl::Error> {
1439            let _response = fidl::client::decode_transaction_body::<
1440                fidl::encoding::EmptyPayload,
1441                fidl::encoding::DefaultFuchsiaResourceDialect,
1442                0x3d38ad5b0f4f49cf,
1443            >(_buf?)?;
1444            Ok(_response)
1445        }
1446        self.client.send_query_and_decode::<TablePayload, ()>(
1447            payload,
1448            0x3d38ad5b0f4f49cf,
1449            fidl::encoding::DynamicFlags::empty(),
1450            _decode,
1451        )
1452    }
1453
1454    type TwoWayUnionRequestResponseFut =
1455        fidl::client::QueryResponseFut<(), fidl::encoding::DefaultFuchsiaResourceDialect>;
1456    fn r#two_way_union_request(
1457        &self,
1458        mut payload: &UnionPayload,
1459    ) -> Self::TwoWayUnionRequestResponseFut {
1460        fn _decode(
1461            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
1462        ) -> Result<(), fidl::Error> {
1463            let _response = fidl::client::decode_transaction_body::<
1464                fidl::encoding::EmptyPayload,
1465                fidl::encoding::DefaultFuchsiaResourceDialect,
1466                0x7adb1c265a378e77,
1467            >(_buf?)?;
1468            Ok(_response)
1469        }
1470        self.client.send_query_and_decode::<UnionPayload, ()>(
1471            payload,
1472            0x7adb1c265a378e77,
1473            fidl::encoding::DynamicFlags::empty(),
1474            _decode,
1475        )
1476    }
1477
1478    fn r#one_way_no_request(&self) -> Result<(), fidl::Error> {
1479        self.client.send::<fidl::encoding::EmptyPayload>(
1480            (),
1481            0xc376730a2cd8a05,
1482            fidl::encoding::DynamicFlags::empty(),
1483        )
1484    }
1485
1486    fn r#one_way_struct_request(&self, mut some_field: i32) -> Result<(), fidl::Error> {
1487        self.client.send::<NonEmptyPayload>(
1488            (some_field,),
1489            0x2618da6f51e0dcd2,
1490            fidl::encoding::DynamicFlags::empty(),
1491        )
1492    }
1493
1494    fn r#one_way_table_request(&self, mut payload: &TablePayload) -> Result<(), fidl::Error> {
1495        self.client.send::<TablePayload>(
1496            payload,
1497            0x1a4b7d32eaed401f,
1498            fidl::encoding::DynamicFlags::empty(),
1499        )
1500    }
1501
1502    fn r#one_way_union_request(&self, mut payload: &UnionPayload) -> Result<(), fidl::Error> {
1503        self.client.send::<UnionPayload>(
1504            payload,
1505            0x142b3cd9ea530de5,
1506            fidl::encoding::DynamicFlags::empty(),
1507        )
1508    }
1509}
1510
1511pub struct ClosedTargetEventStream {
1512    event_receiver: fidl::client::EventReceiver<fidl::encoding::DefaultFuchsiaResourceDialect>,
1513}
1514
1515impl std::marker::Unpin for ClosedTargetEventStream {}
1516
1517impl futures::stream::FusedStream for ClosedTargetEventStream {
1518    fn is_terminated(&self) -> bool {
1519        self.event_receiver.is_terminated()
1520    }
1521}
1522
1523impl futures::Stream for ClosedTargetEventStream {
1524    type Item = Result<ClosedTargetEvent, fidl::Error>;
1525
1526    fn poll_next(
1527        mut self: std::pin::Pin<&mut Self>,
1528        cx: &mut std::task::Context<'_>,
1529    ) -> std::task::Poll<Option<Self::Item>> {
1530        match futures::ready!(futures::stream::StreamExt::poll_next_unpin(
1531            &mut self.event_receiver,
1532            cx
1533        )?) {
1534            Some(buf) => std::task::Poll::Ready(Some(ClosedTargetEvent::decode(buf))),
1535            None => std::task::Poll::Ready(None),
1536        }
1537    }
1538}
1539
1540#[derive(Debug)]
1541pub enum ClosedTargetEvent {
1542    OnEventNoPayload {},
1543    OnEventStructPayload { some_field: i32 },
1544    OnEventTablePayload { payload: TablePayload },
1545    OnEventUnionPayload { payload: UnionPayload },
1546}
1547
1548impl ClosedTargetEvent {
1549    #[allow(irrefutable_let_patterns)]
1550    pub fn into_on_event_no_payload(self) -> Option<()> {
1551        if let ClosedTargetEvent::OnEventNoPayload {} = self {
1552            Some(())
1553        } else {
1554            None
1555        }
1556    }
1557    #[allow(irrefutable_let_patterns)]
1558    pub fn into_on_event_struct_payload(self) -> Option<i32> {
1559        if let ClosedTargetEvent::OnEventStructPayload { some_field } = self {
1560            Some((some_field))
1561        } else {
1562            None
1563        }
1564    }
1565    #[allow(irrefutable_let_patterns)]
1566    pub fn into_on_event_table_payload(self) -> Option<TablePayload> {
1567        if let ClosedTargetEvent::OnEventTablePayload { payload } = self {
1568            Some((payload))
1569        } else {
1570            None
1571        }
1572    }
1573    #[allow(irrefutable_let_patterns)]
1574    pub fn into_on_event_union_payload(self) -> Option<UnionPayload> {
1575        if let ClosedTargetEvent::OnEventUnionPayload { payload } = self {
1576            Some((payload))
1577        } else {
1578            None
1579        }
1580    }
1581
1582    /// Decodes a message buffer as a [`ClosedTargetEvent`].
1583    fn decode(
1584        mut buf: <fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc,
1585    ) -> Result<ClosedTargetEvent, fidl::Error> {
1586        let (bytes, _handles) = buf.split_mut();
1587        let (tx_header, _body_bytes) = fidl::encoding::decode_transaction_header(bytes)?;
1588        debug_assert_eq!(tx_header.tx_id, 0);
1589        match tx_header.ordinal {
1590            0x4ee7b8d3e6bb36a6 => {
1591                let mut out = fidl::new_empty!(
1592                    fidl::encoding::EmptyPayload,
1593                    fidl::encoding::DefaultFuchsiaResourceDialect
1594                );
1595                fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&tx_header, _body_bytes, _handles, &mut out)?;
1596                Ok((ClosedTargetEvent::OnEventNoPayload {}))
1597            }
1598            0x48e8c897893ae266 => {
1599                let mut out = fidl::new_empty!(
1600                    NonEmptyPayload,
1601                    fidl::encoding::DefaultFuchsiaResourceDialect
1602                );
1603                fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<NonEmptyPayload>(&tx_header, _body_bytes, _handles, &mut out)?;
1604                Ok((ClosedTargetEvent::OnEventStructPayload { some_field: out.some_field }))
1605            }
1606            0x72837525f4f3e746 => {
1607                let mut out =
1608                    fidl::new_empty!(TablePayload, fidl::encoding::DefaultFuchsiaResourceDialect);
1609                fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<TablePayload>(&tx_header, _body_bytes, _handles, &mut out)?;
1610                Ok((ClosedTargetEvent::OnEventTablePayload { payload: out }))
1611            }
1612            0x69c6390e1ac48ea0 => {
1613                let mut out =
1614                    fidl::new_empty!(UnionPayload, fidl::encoding::DefaultFuchsiaResourceDialect);
1615                fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<UnionPayload>(&tx_header, _body_bytes, _handles, &mut out)?;
1616                Ok((ClosedTargetEvent::OnEventUnionPayload { payload: out }))
1617            }
1618            _ => Err(fidl::Error::UnknownOrdinal {
1619                ordinal: tx_header.ordinal,
1620                protocol_name: <ClosedTargetMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME,
1621            }),
1622        }
1623    }
1624}
1625
1626/// A Stream of incoming requests for fidl.clientsuite/ClosedTarget.
1627pub struct ClosedTargetRequestStream {
1628    inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
1629    is_terminated: bool,
1630}
1631
1632impl std::marker::Unpin for ClosedTargetRequestStream {}
1633
1634impl futures::stream::FusedStream for ClosedTargetRequestStream {
1635    fn is_terminated(&self) -> bool {
1636        self.is_terminated
1637    }
1638}
1639
1640impl fidl::endpoints::RequestStream for ClosedTargetRequestStream {
1641    type Protocol = ClosedTargetMarker;
1642    type ControlHandle = ClosedTargetControlHandle;
1643
1644    fn from_channel(channel: ::fidl::AsyncChannel) -> Self {
1645        Self { inner: std::sync::Arc::new(fidl::ServeInner::new(channel)), is_terminated: false }
1646    }
1647
1648    fn control_handle(&self) -> Self::ControlHandle {
1649        ClosedTargetControlHandle { inner: self.inner.clone() }
1650    }
1651
1652    fn into_inner(
1653        self,
1654    ) -> (::std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>, bool)
1655    {
1656        (self.inner, self.is_terminated)
1657    }
1658
1659    fn from_inner(
1660        inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
1661        is_terminated: bool,
1662    ) -> Self {
1663        Self { inner, is_terminated }
1664    }
1665}
1666
1667impl futures::Stream for ClosedTargetRequestStream {
1668    type Item = Result<ClosedTargetRequest, fidl::Error>;
1669
1670    fn poll_next(
1671        mut self: std::pin::Pin<&mut Self>,
1672        cx: &mut std::task::Context<'_>,
1673    ) -> std::task::Poll<Option<Self::Item>> {
1674        let this = &mut *self;
1675        if this.inner.check_shutdown(cx) {
1676            this.is_terminated = true;
1677            return std::task::Poll::Ready(None);
1678        }
1679        if this.is_terminated {
1680            panic!("polled ClosedTargetRequestStream after completion");
1681        }
1682        fidl::encoding::with_tls_decode_buf::<_, fidl::encoding::DefaultFuchsiaResourceDialect>(
1683            |bytes, handles| {
1684                match this.inner.channel().read_etc(cx, bytes, handles) {
1685                    std::task::Poll::Ready(Ok(())) => {}
1686                    std::task::Poll::Pending => return std::task::Poll::Pending,
1687                    std::task::Poll::Ready(Err(zx_status::Status::PEER_CLOSED)) => {
1688                        this.is_terminated = true;
1689                        return std::task::Poll::Ready(None);
1690                    }
1691                    std::task::Poll::Ready(Err(e)) => {
1692                        return std::task::Poll::Ready(Some(Err(fidl::Error::ServerRequestRead(
1693                            e.into(),
1694                        ))))
1695                    }
1696                }
1697
1698                // A message has been received from the channel
1699                let (header, _body_bytes) = fidl::encoding::decode_transaction_header(bytes)?;
1700
1701                std::task::Poll::Ready(Some(match header.ordinal {
1702                    0x7a722961424c1720 => {
1703                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
1704                        let mut req = fidl::new_empty!(
1705                            fidl::encoding::EmptyPayload,
1706                            fidl::encoding::DefaultFuchsiaResourceDialect
1707                        );
1708                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&header, _body_bytes, handles, &mut req)?;
1709                        let control_handle =
1710                            ClosedTargetControlHandle { inner: this.inner.clone() };
1711                        Ok(ClosedTargetRequest::TwoWayNoPayload {
1712                            responder: ClosedTargetTwoWayNoPayloadResponder {
1713                                control_handle: std::mem::ManuallyDrop::new(control_handle),
1714                                tx_id: header.tx_id,
1715                            },
1716                        })
1717                    }
1718                    0x3a402118bad781bd => {
1719                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
1720                        let mut req = fidl::new_empty!(
1721                            fidl::encoding::EmptyPayload,
1722                            fidl::encoding::DefaultFuchsiaResourceDialect
1723                        );
1724                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&header, _body_bytes, handles, &mut req)?;
1725                        let control_handle =
1726                            ClosedTargetControlHandle { inner: this.inner.clone() };
1727                        Ok(ClosedTargetRequest::TwoWayStructPayload {
1728                            responder: ClosedTargetTwoWayStructPayloadResponder {
1729                                control_handle: std::mem::ManuallyDrop::new(control_handle),
1730                                tx_id: header.tx_id,
1731                            },
1732                        })
1733                    }
1734                    0x53be101c241c66bc => {
1735                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
1736                        let mut req = fidl::new_empty!(
1737                            fidl::encoding::EmptyPayload,
1738                            fidl::encoding::DefaultFuchsiaResourceDialect
1739                        );
1740                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&header, _body_bytes, handles, &mut req)?;
1741                        let control_handle =
1742                            ClosedTargetControlHandle { inner: this.inner.clone() };
1743                        Ok(ClosedTargetRequest::TwoWayTablePayload {
1744                            responder: ClosedTargetTwoWayTablePayloadResponder {
1745                                control_handle: std::mem::ManuallyDrop::new(control_handle),
1746                                tx_id: header.tx_id,
1747                            },
1748                        })
1749                    }
1750                    0x1ff7f745ab608f8c => {
1751                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
1752                        let mut req = fidl::new_empty!(
1753                            fidl::encoding::EmptyPayload,
1754                            fidl::encoding::DefaultFuchsiaResourceDialect
1755                        );
1756                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&header, _body_bytes, handles, &mut req)?;
1757                        let control_handle =
1758                            ClosedTargetControlHandle { inner: this.inner.clone() };
1759                        Ok(ClosedTargetRequest::TwoWayUnionPayload {
1760                            responder: ClosedTargetTwoWayUnionPayloadResponder {
1761                                control_handle: std::mem::ManuallyDrop::new(control_handle),
1762                                tx_id: header.tx_id,
1763                            },
1764                        })
1765                    }
1766                    0x62b4861c443bbc0b => {
1767                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
1768                        let mut req = fidl::new_empty!(
1769                            fidl::encoding::EmptyPayload,
1770                            fidl::encoding::DefaultFuchsiaResourceDialect
1771                        );
1772                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&header, _body_bytes, handles, &mut req)?;
1773                        let control_handle =
1774                            ClosedTargetControlHandle { inner: this.inner.clone() };
1775                        Ok(ClosedTargetRequest::TwoWayStructPayloadErr {
1776                            responder: ClosedTargetTwoWayStructPayloadErrResponder {
1777                                control_handle: std::mem::ManuallyDrop::new(control_handle),
1778                                tx_id: header.tx_id,
1779                            },
1780                        })
1781                    }
1782                    0x4ff77b4a913be5b6 => {
1783                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
1784                        let mut req = fidl::new_empty!(
1785                            NonEmptyPayload,
1786                            fidl::encoding::DefaultFuchsiaResourceDialect
1787                        );
1788                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<NonEmptyPayload>(&header, _body_bytes, handles, &mut req)?;
1789                        let control_handle =
1790                            ClosedTargetControlHandle { inner: this.inner.clone() };
1791                        Ok(ClosedTargetRequest::TwoWayStructRequest {
1792                            some_field: req.some_field,
1793
1794                            responder: ClosedTargetTwoWayStructRequestResponder {
1795                                control_handle: std::mem::ManuallyDrop::new(control_handle),
1796                                tx_id: header.tx_id,
1797                            },
1798                        })
1799                    }
1800                    0x3d38ad5b0f4f49cf => {
1801                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
1802                        let mut req = fidl::new_empty!(
1803                            TablePayload,
1804                            fidl::encoding::DefaultFuchsiaResourceDialect
1805                        );
1806                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<TablePayload>(&header, _body_bytes, handles, &mut req)?;
1807                        let control_handle =
1808                            ClosedTargetControlHandle { inner: this.inner.clone() };
1809                        Ok(ClosedTargetRequest::TwoWayTableRequest {
1810                            payload: req,
1811                            responder: ClosedTargetTwoWayTableRequestResponder {
1812                                control_handle: std::mem::ManuallyDrop::new(control_handle),
1813                                tx_id: header.tx_id,
1814                            },
1815                        })
1816                    }
1817                    0x7adb1c265a378e77 => {
1818                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
1819                        let mut req = fidl::new_empty!(
1820                            UnionPayload,
1821                            fidl::encoding::DefaultFuchsiaResourceDialect
1822                        );
1823                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<UnionPayload>(&header, _body_bytes, handles, &mut req)?;
1824                        let control_handle =
1825                            ClosedTargetControlHandle { inner: this.inner.clone() };
1826                        Ok(ClosedTargetRequest::TwoWayUnionRequest {
1827                            payload: req,
1828                            responder: ClosedTargetTwoWayUnionRequestResponder {
1829                                control_handle: std::mem::ManuallyDrop::new(control_handle),
1830                                tx_id: header.tx_id,
1831                            },
1832                        })
1833                    }
1834                    0xc376730a2cd8a05 => {
1835                        header.validate_request_tx_id(fidl::MethodType::OneWay)?;
1836                        let mut req = fidl::new_empty!(
1837                            fidl::encoding::EmptyPayload,
1838                            fidl::encoding::DefaultFuchsiaResourceDialect
1839                        );
1840                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&header, _body_bytes, handles, &mut req)?;
1841                        let control_handle =
1842                            ClosedTargetControlHandle { inner: this.inner.clone() };
1843                        Ok(ClosedTargetRequest::OneWayNoRequest { control_handle })
1844                    }
1845                    0x2618da6f51e0dcd2 => {
1846                        header.validate_request_tx_id(fidl::MethodType::OneWay)?;
1847                        let mut req = fidl::new_empty!(
1848                            NonEmptyPayload,
1849                            fidl::encoding::DefaultFuchsiaResourceDialect
1850                        );
1851                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<NonEmptyPayload>(&header, _body_bytes, handles, &mut req)?;
1852                        let control_handle =
1853                            ClosedTargetControlHandle { inner: this.inner.clone() };
1854                        Ok(ClosedTargetRequest::OneWayStructRequest {
1855                            some_field: req.some_field,
1856
1857                            control_handle,
1858                        })
1859                    }
1860                    0x1a4b7d32eaed401f => {
1861                        header.validate_request_tx_id(fidl::MethodType::OneWay)?;
1862                        let mut req = fidl::new_empty!(
1863                            TablePayload,
1864                            fidl::encoding::DefaultFuchsiaResourceDialect
1865                        );
1866                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<TablePayload>(&header, _body_bytes, handles, &mut req)?;
1867                        let control_handle =
1868                            ClosedTargetControlHandle { inner: this.inner.clone() };
1869                        Ok(ClosedTargetRequest::OneWayTableRequest { payload: req, control_handle })
1870                    }
1871                    0x142b3cd9ea530de5 => {
1872                        header.validate_request_tx_id(fidl::MethodType::OneWay)?;
1873                        let mut req = fidl::new_empty!(
1874                            UnionPayload,
1875                            fidl::encoding::DefaultFuchsiaResourceDialect
1876                        );
1877                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<UnionPayload>(&header, _body_bytes, handles, &mut req)?;
1878                        let control_handle =
1879                            ClosedTargetControlHandle { inner: this.inner.clone() };
1880                        Ok(ClosedTargetRequest::OneWayUnionRequest { payload: req, control_handle })
1881                    }
1882                    _ => Err(fidl::Error::UnknownOrdinal {
1883                        ordinal: header.ordinal,
1884                        protocol_name:
1885                            <ClosedTargetMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME,
1886                    }),
1887                }))
1888            },
1889        )
1890    }
1891}
1892
1893#[derive(Debug)]
1894pub enum ClosedTargetRequest {
1895    TwoWayNoPayload { responder: ClosedTargetTwoWayNoPayloadResponder },
1896    TwoWayStructPayload { responder: ClosedTargetTwoWayStructPayloadResponder },
1897    TwoWayTablePayload { responder: ClosedTargetTwoWayTablePayloadResponder },
1898    TwoWayUnionPayload { responder: ClosedTargetTwoWayUnionPayloadResponder },
1899    TwoWayStructPayloadErr { responder: ClosedTargetTwoWayStructPayloadErrResponder },
1900    TwoWayStructRequest { some_field: i32, responder: ClosedTargetTwoWayStructRequestResponder },
1901    TwoWayTableRequest { payload: TablePayload, responder: ClosedTargetTwoWayTableRequestResponder },
1902    TwoWayUnionRequest { payload: UnionPayload, responder: ClosedTargetTwoWayUnionRequestResponder },
1903    OneWayNoRequest { control_handle: ClosedTargetControlHandle },
1904    OneWayStructRequest { some_field: i32, control_handle: ClosedTargetControlHandle },
1905    OneWayTableRequest { payload: TablePayload, control_handle: ClosedTargetControlHandle },
1906    OneWayUnionRequest { payload: UnionPayload, control_handle: ClosedTargetControlHandle },
1907}
1908
1909impl ClosedTargetRequest {
1910    #[allow(irrefutable_let_patterns)]
1911    pub fn into_two_way_no_payload(self) -> Option<(ClosedTargetTwoWayNoPayloadResponder)> {
1912        if let ClosedTargetRequest::TwoWayNoPayload { responder } = self {
1913            Some((responder))
1914        } else {
1915            None
1916        }
1917    }
1918
1919    #[allow(irrefutable_let_patterns)]
1920    pub fn into_two_way_struct_payload(self) -> Option<(ClosedTargetTwoWayStructPayloadResponder)> {
1921        if let ClosedTargetRequest::TwoWayStructPayload { responder } = self {
1922            Some((responder))
1923        } else {
1924            None
1925        }
1926    }
1927
1928    #[allow(irrefutable_let_patterns)]
1929    pub fn into_two_way_table_payload(self) -> Option<(ClosedTargetTwoWayTablePayloadResponder)> {
1930        if let ClosedTargetRequest::TwoWayTablePayload { responder } = self {
1931            Some((responder))
1932        } else {
1933            None
1934        }
1935    }
1936
1937    #[allow(irrefutable_let_patterns)]
1938    pub fn into_two_way_union_payload(self) -> Option<(ClosedTargetTwoWayUnionPayloadResponder)> {
1939        if let ClosedTargetRequest::TwoWayUnionPayload { responder } = self {
1940            Some((responder))
1941        } else {
1942            None
1943        }
1944    }
1945
1946    #[allow(irrefutable_let_patterns)]
1947    pub fn into_two_way_struct_payload_err(
1948        self,
1949    ) -> Option<(ClosedTargetTwoWayStructPayloadErrResponder)> {
1950        if let ClosedTargetRequest::TwoWayStructPayloadErr { responder } = self {
1951            Some((responder))
1952        } else {
1953            None
1954        }
1955    }
1956
1957    #[allow(irrefutable_let_patterns)]
1958    pub fn into_two_way_struct_request(
1959        self,
1960    ) -> Option<(i32, ClosedTargetTwoWayStructRequestResponder)> {
1961        if let ClosedTargetRequest::TwoWayStructRequest { some_field, responder } = self {
1962            Some((some_field, responder))
1963        } else {
1964            None
1965        }
1966    }
1967
1968    #[allow(irrefutable_let_patterns)]
1969    pub fn into_two_way_table_request(
1970        self,
1971    ) -> Option<(TablePayload, ClosedTargetTwoWayTableRequestResponder)> {
1972        if let ClosedTargetRequest::TwoWayTableRequest { payload, responder } = self {
1973            Some((payload, responder))
1974        } else {
1975            None
1976        }
1977    }
1978
1979    #[allow(irrefutable_let_patterns)]
1980    pub fn into_two_way_union_request(
1981        self,
1982    ) -> Option<(UnionPayload, ClosedTargetTwoWayUnionRequestResponder)> {
1983        if let ClosedTargetRequest::TwoWayUnionRequest { payload, responder } = self {
1984            Some((payload, responder))
1985        } else {
1986            None
1987        }
1988    }
1989
1990    #[allow(irrefutable_let_patterns)]
1991    pub fn into_one_way_no_request(self) -> Option<(ClosedTargetControlHandle)> {
1992        if let ClosedTargetRequest::OneWayNoRequest { control_handle } = self {
1993            Some((control_handle))
1994        } else {
1995            None
1996        }
1997    }
1998
1999    #[allow(irrefutable_let_patterns)]
2000    pub fn into_one_way_struct_request(self) -> Option<(i32, ClosedTargetControlHandle)> {
2001        if let ClosedTargetRequest::OneWayStructRequest { some_field, control_handle } = self {
2002            Some((some_field, control_handle))
2003        } else {
2004            None
2005        }
2006    }
2007
2008    #[allow(irrefutable_let_patterns)]
2009    pub fn into_one_way_table_request(self) -> Option<(TablePayload, ClosedTargetControlHandle)> {
2010        if let ClosedTargetRequest::OneWayTableRequest { payload, control_handle } = self {
2011            Some((payload, control_handle))
2012        } else {
2013            None
2014        }
2015    }
2016
2017    #[allow(irrefutable_let_patterns)]
2018    pub fn into_one_way_union_request(self) -> Option<(UnionPayload, ClosedTargetControlHandle)> {
2019        if let ClosedTargetRequest::OneWayUnionRequest { payload, control_handle } = self {
2020            Some((payload, control_handle))
2021        } else {
2022            None
2023        }
2024    }
2025
2026    /// Name of the method defined in FIDL
2027    pub fn method_name(&self) -> &'static str {
2028        match *self {
2029            ClosedTargetRequest::TwoWayNoPayload { .. } => "two_way_no_payload",
2030            ClosedTargetRequest::TwoWayStructPayload { .. } => "two_way_struct_payload",
2031            ClosedTargetRequest::TwoWayTablePayload { .. } => "two_way_table_payload",
2032            ClosedTargetRequest::TwoWayUnionPayload { .. } => "two_way_union_payload",
2033            ClosedTargetRequest::TwoWayStructPayloadErr { .. } => "two_way_struct_payload_err",
2034            ClosedTargetRequest::TwoWayStructRequest { .. } => "two_way_struct_request",
2035            ClosedTargetRequest::TwoWayTableRequest { .. } => "two_way_table_request",
2036            ClosedTargetRequest::TwoWayUnionRequest { .. } => "two_way_union_request",
2037            ClosedTargetRequest::OneWayNoRequest { .. } => "one_way_no_request",
2038            ClosedTargetRequest::OneWayStructRequest { .. } => "one_way_struct_request",
2039            ClosedTargetRequest::OneWayTableRequest { .. } => "one_way_table_request",
2040            ClosedTargetRequest::OneWayUnionRequest { .. } => "one_way_union_request",
2041        }
2042    }
2043}
2044
2045#[derive(Debug, Clone)]
2046pub struct ClosedTargetControlHandle {
2047    inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
2048}
2049
2050impl fidl::endpoints::ControlHandle for ClosedTargetControlHandle {
2051    fn shutdown(&self) {
2052        self.inner.shutdown()
2053    }
2054    fn shutdown_with_epitaph(&self, status: zx_status::Status) {
2055        self.inner.shutdown_with_epitaph(status)
2056    }
2057
2058    fn is_closed(&self) -> bool {
2059        self.inner.channel().is_closed()
2060    }
2061    fn on_closed(&self) -> fidl::OnSignalsRef<'_> {
2062        self.inner.channel().on_closed()
2063    }
2064
2065    #[cfg(target_os = "fuchsia")]
2066    fn signal_peer(
2067        &self,
2068        clear_mask: zx::Signals,
2069        set_mask: zx::Signals,
2070    ) -> Result<(), zx_status::Status> {
2071        use fidl::Peered;
2072        self.inner.channel().signal_peer(clear_mask, set_mask)
2073    }
2074}
2075
2076impl ClosedTargetControlHandle {
2077    pub fn send_on_event_no_payload(&self) -> Result<(), fidl::Error> {
2078        self.inner.send::<fidl::encoding::EmptyPayload>(
2079            (),
2080            0,
2081            0x4ee7b8d3e6bb36a6,
2082            fidl::encoding::DynamicFlags::empty(),
2083        )
2084    }
2085
2086    pub fn send_on_event_struct_payload(&self, mut some_field: i32) -> Result<(), fidl::Error> {
2087        self.inner.send::<NonEmptyPayload>(
2088            (some_field,),
2089            0,
2090            0x48e8c897893ae266,
2091            fidl::encoding::DynamicFlags::empty(),
2092        )
2093    }
2094
2095    pub fn send_on_event_table_payload(
2096        &self,
2097        mut payload: &TablePayload,
2098    ) -> Result<(), fidl::Error> {
2099        self.inner.send::<TablePayload>(
2100            payload,
2101            0,
2102            0x72837525f4f3e746,
2103            fidl::encoding::DynamicFlags::empty(),
2104        )
2105    }
2106
2107    pub fn send_on_event_union_payload(
2108        &self,
2109        mut payload: &UnionPayload,
2110    ) -> Result<(), fidl::Error> {
2111        self.inner.send::<UnionPayload>(
2112            payload,
2113            0,
2114            0x69c6390e1ac48ea0,
2115            fidl::encoding::DynamicFlags::empty(),
2116        )
2117    }
2118}
2119
2120#[must_use = "FIDL methods require a response to be sent"]
2121#[derive(Debug)]
2122pub struct ClosedTargetTwoWayNoPayloadResponder {
2123    control_handle: std::mem::ManuallyDrop<ClosedTargetControlHandle>,
2124    tx_id: u32,
2125}
2126
2127/// Set the the channel to be shutdown (see [`ClosedTargetControlHandle::shutdown`])
2128/// if the responder is dropped without sending a response, so that the client
2129/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
2130impl std::ops::Drop for ClosedTargetTwoWayNoPayloadResponder {
2131    fn drop(&mut self) {
2132        self.control_handle.shutdown();
2133        // Safety: drops once, never accessed again
2134        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
2135    }
2136}
2137
2138impl fidl::endpoints::Responder for ClosedTargetTwoWayNoPayloadResponder {
2139    type ControlHandle = ClosedTargetControlHandle;
2140
2141    fn control_handle(&self) -> &ClosedTargetControlHandle {
2142        &self.control_handle
2143    }
2144
2145    fn drop_without_shutdown(mut self) {
2146        // Safety: drops once, never accessed again due to mem::forget
2147        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
2148        // Prevent Drop from running (which would shut down the channel)
2149        std::mem::forget(self);
2150    }
2151}
2152
2153impl ClosedTargetTwoWayNoPayloadResponder {
2154    /// Sends a response to the FIDL transaction.
2155    ///
2156    /// Sets the channel to shutdown if an error occurs.
2157    pub fn send(self) -> Result<(), fidl::Error> {
2158        let _result = self.send_raw();
2159        if _result.is_err() {
2160            self.control_handle.shutdown();
2161        }
2162        self.drop_without_shutdown();
2163        _result
2164    }
2165
2166    /// Similar to "send" but does not shutdown the channel if an error occurs.
2167    pub fn send_no_shutdown_on_err(self) -> Result<(), fidl::Error> {
2168        let _result = self.send_raw();
2169        self.drop_without_shutdown();
2170        _result
2171    }
2172
2173    fn send_raw(&self) -> Result<(), fidl::Error> {
2174        self.control_handle.inner.send::<fidl::encoding::EmptyPayload>(
2175            (),
2176            self.tx_id,
2177            0x7a722961424c1720,
2178            fidl::encoding::DynamicFlags::empty(),
2179        )
2180    }
2181}
2182
2183#[must_use = "FIDL methods require a response to be sent"]
2184#[derive(Debug)]
2185pub struct ClosedTargetTwoWayStructPayloadResponder {
2186    control_handle: std::mem::ManuallyDrop<ClosedTargetControlHandle>,
2187    tx_id: u32,
2188}
2189
2190/// Set the the channel to be shutdown (see [`ClosedTargetControlHandle::shutdown`])
2191/// if the responder is dropped without sending a response, so that the client
2192/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
2193impl std::ops::Drop for ClosedTargetTwoWayStructPayloadResponder {
2194    fn drop(&mut self) {
2195        self.control_handle.shutdown();
2196        // Safety: drops once, never accessed again
2197        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
2198    }
2199}
2200
2201impl fidl::endpoints::Responder for ClosedTargetTwoWayStructPayloadResponder {
2202    type ControlHandle = ClosedTargetControlHandle;
2203
2204    fn control_handle(&self) -> &ClosedTargetControlHandle {
2205        &self.control_handle
2206    }
2207
2208    fn drop_without_shutdown(mut self) {
2209        // Safety: drops once, never accessed again due to mem::forget
2210        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
2211        // Prevent Drop from running (which would shut down the channel)
2212        std::mem::forget(self);
2213    }
2214}
2215
2216impl ClosedTargetTwoWayStructPayloadResponder {
2217    /// Sends a response to the FIDL transaction.
2218    ///
2219    /// Sets the channel to shutdown if an error occurs.
2220    pub fn send(self, mut some_field: i32) -> Result<(), fidl::Error> {
2221        let _result = self.send_raw(some_field);
2222        if _result.is_err() {
2223            self.control_handle.shutdown();
2224        }
2225        self.drop_without_shutdown();
2226        _result
2227    }
2228
2229    /// Similar to "send" but does not shutdown the channel if an error occurs.
2230    pub fn send_no_shutdown_on_err(self, mut some_field: i32) -> Result<(), fidl::Error> {
2231        let _result = self.send_raw(some_field);
2232        self.drop_without_shutdown();
2233        _result
2234    }
2235
2236    fn send_raw(&self, mut some_field: i32) -> Result<(), fidl::Error> {
2237        self.control_handle.inner.send::<NonEmptyPayload>(
2238            (some_field,),
2239            self.tx_id,
2240            0x3a402118bad781bd,
2241            fidl::encoding::DynamicFlags::empty(),
2242        )
2243    }
2244}
2245
2246#[must_use = "FIDL methods require a response to be sent"]
2247#[derive(Debug)]
2248pub struct ClosedTargetTwoWayTablePayloadResponder {
2249    control_handle: std::mem::ManuallyDrop<ClosedTargetControlHandle>,
2250    tx_id: u32,
2251}
2252
2253/// Set the the channel to be shutdown (see [`ClosedTargetControlHandle::shutdown`])
2254/// if the responder is dropped without sending a response, so that the client
2255/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
2256impl std::ops::Drop for ClosedTargetTwoWayTablePayloadResponder {
2257    fn drop(&mut self) {
2258        self.control_handle.shutdown();
2259        // Safety: drops once, never accessed again
2260        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
2261    }
2262}
2263
2264impl fidl::endpoints::Responder for ClosedTargetTwoWayTablePayloadResponder {
2265    type ControlHandle = ClosedTargetControlHandle;
2266
2267    fn control_handle(&self) -> &ClosedTargetControlHandle {
2268        &self.control_handle
2269    }
2270
2271    fn drop_without_shutdown(mut self) {
2272        // Safety: drops once, never accessed again due to mem::forget
2273        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
2274        // Prevent Drop from running (which would shut down the channel)
2275        std::mem::forget(self);
2276    }
2277}
2278
2279impl ClosedTargetTwoWayTablePayloadResponder {
2280    /// Sends a response to the FIDL transaction.
2281    ///
2282    /// Sets the channel to shutdown if an error occurs.
2283    pub fn send(self, mut payload: &TablePayload) -> Result<(), fidl::Error> {
2284        let _result = self.send_raw(payload);
2285        if _result.is_err() {
2286            self.control_handle.shutdown();
2287        }
2288        self.drop_without_shutdown();
2289        _result
2290    }
2291
2292    /// Similar to "send" but does not shutdown the channel if an error occurs.
2293    pub fn send_no_shutdown_on_err(self, mut payload: &TablePayload) -> Result<(), fidl::Error> {
2294        let _result = self.send_raw(payload);
2295        self.drop_without_shutdown();
2296        _result
2297    }
2298
2299    fn send_raw(&self, mut payload: &TablePayload) -> Result<(), fidl::Error> {
2300        self.control_handle.inner.send::<TablePayload>(
2301            payload,
2302            self.tx_id,
2303            0x53be101c241c66bc,
2304            fidl::encoding::DynamicFlags::empty(),
2305        )
2306    }
2307}
2308
2309#[must_use = "FIDL methods require a response to be sent"]
2310#[derive(Debug)]
2311pub struct ClosedTargetTwoWayUnionPayloadResponder {
2312    control_handle: std::mem::ManuallyDrop<ClosedTargetControlHandle>,
2313    tx_id: u32,
2314}
2315
2316/// Set the the channel to be shutdown (see [`ClosedTargetControlHandle::shutdown`])
2317/// if the responder is dropped without sending a response, so that the client
2318/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
2319impl std::ops::Drop for ClosedTargetTwoWayUnionPayloadResponder {
2320    fn drop(&mut self) {
2321        self.control_handle.shutdown();
2322        // Safety: drops once, never accessed again
2323        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
2324    }
2325}
2326
2327impl fidl::endpoints::Responder for ClosedTargetTwoWayUnionPayloadResponder {
2328    type ControlHandle = ClosedTargetControlHandle;
2329
2330    fn control_handle(&self) -> &ClosedTargetControlHandle {
2331        &self.control_handle
2332    }
2333
2334    fn drop_without_shutdown(mut self) {
2335        // Safety: drops once, never accessed again due to mem::forget
2336        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
2337        // Prevent Drop from running (which would shut down the channel)
2338        std::mem::forget(self);
2339    }
2340}
2341
2342impl ClosedTargetTwoWayUnionPayloadResponder {
2343    /// Sends a response to the FIDL transaction.
2344    ///
2345    /// Sets the channel to shutdown if an error occurs.
2346    pub fn send(self, mut payload: &UnionPayload) -> Result<(), fidl::Error> {
2347        let _result = self.send_raw(payload);
2348        if _result.is_err() {
2349            self.control_handle.shutdown();
2350        }
2351        self.drop_without_shutdown();
2352        _result
2353    }
2354
2355    /// Similar to "send" but does not shutdown the channel if an error occurs.
2356    pub fn send_no_shutdown_on_err(self, mut payload: &UnionPayload) -> Result<(), fidl::Error> {
2357        let _result = self.send_raw(payload);
2358        self.drop_without_shutdown();
2359        _result
2360    }
2361
2362    fn send_raw(&self, mut payload: &UnionPayload) -> Result<(), fidl::Error> {
2363        self.control_handle.inner.send::<UnionPayload>(
2364            payload,
2365            self.tx_id,
2366            0x1ff7f745ab608f8c,
2367            fidl::encoding::DynamicFlags::empty(),
2368        )
2369    }
2370}
2371
2372#[must_use = "FIDL methods require a response to be sent"]
2373#[derive(Debug)]
2374pub struct ClosedTargetTwoWayStructPayloadErrResponder {
2375    control_handle: std::mem::ManuallyDrop<ClosedTargetControlHandle>,
2376    tx_id: u32,
2377}
2378
2379/// Set the the channel to be shutdown (see [`ClosedTargetControlHandle::shutdown`])
2380/// if the responder is dropped without sending a response, so that the client
2381/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
2382impl std::ops::Drop for ClosedTargetTwoWayStructPayloadErrResponder {
2383    fn drop(&mut self) {
2384        self.control_handle.shutdown();
2385        // Safety: drops once, never accessed again
2386        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
2387    }
2388}
2389
2390impl fidl::endpoints::Responder for ClosedTargetTwoWayStructPayloadErrResponder {
2391    type ControlHandle = ClosedTargetControlHandle;
2392
2393    fn control_handle(&self) -> &ClosedTargetControlHandle {
2394        &self.control_handle
2395    }
2396
2397    fn drop_without_shutdown(mut self) {
2398        // Safety: drops once, never accessed again due to mem::forget
2399        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
2400        // Prevent Drop from running (which would shut down the channel)
2401        std::mem::forget(self);
2402    }
2403}
2404
2405impl ClosedTargetTwoWayStructPayloadErrResponder {
2406    /// Sends a response to the FIDL transaction.
2407    ///
2408    /// Sets the channel to shutdown if an error occurs.
2409    pub fn send(self, mut result: Result<i32, i32>) -> Result<(), fidl::Error> {
2410        let _result = self.send_raw(result);
2411        if _result.is_err() {
2412            self.control_handle.shutdown();
2413        }
2414        self.drop_without_shutdown();
2415        _result
2416    }
2417
2418    /// Similar to "send" but does not shutdown the channel if an error occurs.
2419    pub fn send_no_shutdown_on_err(self, mut result: Result<i32, i32>) -> Result<(), fidl::Error> {
2420        let _result = self.send_raw(result);
2421        self.drop_without_shutdown();
2422        _result
2423    }
2424
2425    fn send_raw(&self, mut result: Result<i32, i32>) -> Result<(), fidl::Error> {
2426        self.control_handle.inner.send::<fidl::encoding::ResultType<NonEmptyPayload, i32>>(
2427            result.map(|some_field| (some_field,)),
2428            self.tx_id,
2429            0x62b4861c443bbc0b,
2430            fidl::encoding::DynamicFlags::empty(),
2431        )
2432    }
2433}
2434
2435#[must_use = "FIDL methods require a response to be sent"]
2436#[derive(Debug)]
2437pub struct ClosedTargetTwoWayStructRequestResponder {
2438    control_handle: std::mem::ManuallyDrop<ClosedTargetControlHandle>,
2439    tx_id: u32,
2440}
2441
2442/// Set the the channel to be shutdown (see [`ClosedTargetControlHandle::shutdown`])
2443/// if the responder is dropped without sending a response, so that the client
2444/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
2445impl std::ops::Drop for ClosedTargetTwoWayStructRequestResponder {
2446    fn drop(&mut self) {
2447        self.control_handle.shutdown();
2448        // Safety: drops once, never accessed again
2449        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
2450    }
2451}
2452
2453impl fidl::endpoints::Responder for ClosedTargetTwoWayStructRequestResponder {
2454    type ControlHandle = ClosedTargetControlHandle;
2455
2456    fn control_handle(&self) -> &ClosedTargetControlHandle {
2457        &self.control_handle
2458    }
2459
2460    fn drop_without_shutdown(mut self) {
2461        // Safety: drops once, never accessed again due to mem::forget
2462        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
2463        // Prevent Drop from running (which would shut down the channel)
2464        std::mem::forget(self);
2465    }
2466}
2467
2468impl ClosedTargetTwoWayStructRequestResponder {
2469    /// Sends a response to the FIDL transaction.
2470    ///
2471    /// Sets the channel to shutdown if an error occurs.
2472    pub fn send(self) -> Result<(), fidl::Error> {
2473        let _result = self.send_raw();
2474        if _result.is_err() {
2475            self.control_handle.shutdown();
2476        }
2477        self.drop_without_shutdown();
2478        _result
2479    }
2480
2481    /// Similar to "send" but does not shutdown the channel if an error occurs.
2482    pub fn send_no_shutdown_on_err(self) -> Result<(), fidl::Error> {
2483        let _result = self.send_raw();
2484        self.drop_without_shutdown();
2485        _result
2486    }
2487
2488    fn send_raw(&self) -> Result<(), fidl::Error> {
2489        self.control_handle.inner.send::<fidl::encoding::EmptyPayload>(
2490            (),
2491            self.tx_id,
2492            0x4ff77b4a913be5b6,
2493            fidl::encoding::DynamicFlags::empty(),
2494        )
2495    }
2496}
2497
2498#[must_use = "FIDL methods require a response to be sent"]
2499#[derive(Debug)]
2500pub struct ClosedTargetTwoWayTableRequestResponder {
2501    control_handle: std::mem::ManuallyDrop<ClosedTargetControlHandle>,
2502    tx_id: u32,
2503}
2504
2505/// Set the the channel to be shutdown (see [`ClosedTargetControlHandle::shutdown`])
2506/// if the responder is dropped without sending a response, so that the client
2507/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
2508impl std::ops::Drop for ClosedTargetTwoWayTableRequestResponder {
2509    fn drop(&mut self) {
2510        self.control_handle.shutdown();
2511        // Safety: drops once, never accessed again
2512        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
2513    }
2514}
2515
2516impl fidl::endpoints::Responder for ClosedTargetTwoWayTableRequestResponder {
2517    type ControlHandle = ClosedTargetControlHandle;
2518
2519    fn control_handle(&self) -> &ClosedTargetControlHandle {
2520        &self.control_handle
2521    }
2522
2523    fn drop_without_shutdown(mut self) {
2524        // Safety: drops once, never accessed again due to mem::forget
2525        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
2526        // Prevent Drop from running (which would shut down the channel)
2527        std::mem::forget(self);
2528    }
2529}
2530
2531impl ClosedTargetTwoWayTableRequestResponder {
2532    /// Sends a response to the FIDL transaction.
2533    ///
2534    /// Sets the channel to shutdown if an error occurs.
2535    pub fn send(self) -> Result<(), fidl::Error> {
2536        let _result = self.send_raw();
2537        if _result.is_err() {
2538            self.control_handle.shutdown();
2539        }
2540        self.drop_without_shutdown();
2541        _result
2542    }
2543
2544    /// Similar to "send" but does not shutdown the channel if an error occurs.
2545    pub fn send_no_shutdown_on_err(self) -> Result<(), fidl::Error> {
2546        let _result = self.send_raw();
2547        self.drop_without_shutdown();
2548        _result
2549    }
2550
2551    fn send_raw(&self) -> Result<(), fidl::Error> {
2552        self.control_handle.inner.send::<fidl::encoding::EmptyPayload>(
2553            (),
2554            self.tx_id,
2555            0x3d38ad5b0f4f49cf,
2556            fidl::encoding::DynamicFlags::empty(),
2557        )
2558    }
2559}
2560
2561#[must_use = "FIDL methods require a response to be sent"]
2562#[derive(Debug)]
2563pub struct ClosedTargetTwoWayUnionRequestResponder {
2564    control_handle: std::mem::ManuallyDrop<ClosedTargetControlHandle>,
2565    tx_id: u32,
2566}
2567
2568/// Set the the channel to be shutdown (see [`ClosedTargetControlHandle::shutdown`])
2569/// if the responder is dropped without sending a response, so that the client
2570/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
2571impl std::ops::Drop for ClosedTargetTwoWayUnionRequestResponder {
2572    fn drop(&mut self) {
2573        self.control_handle.shutdown();
2574        // Safety: drops once, never accessed again
2575        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
2576    }
2577}
2578
2579impl fidl::endpoints::Responder for ClosedTargetTwoWayUnionRequestResponder {
2580    type ControlHandle = ClosedTargetControlHandle;
2581
2582    fn control_handle(&self) -> &ClosedTargetControlHandle {
2583        &self.control_handle
2584    }
2585
2586    fn drop_without_shutdown(mut self) {
2587        // Safety: drops once, never accessed again due to mem::forget
2588        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
2589        // Prevent Drop from running (which would shut down the channel)
2590        std::mem::forget(self);
2591    }
2592}
2593
2594impl ClosedTargetTwoWayUnionRequestResponder {
2595    /// Sends a response to the FIDL transaction.
2596    ///
2597    /// Sets the channel to shutdown if an error occurs.
2598    pub fn send(self) -> Result<(), fidl::Error> {
2599        let _result = self.send_raw();
2600        if _result.is_err() {
2601            self.control_handle.shutdown();
2602        }
2603        self.drop_without_shutdown();
2604        _result
2605    }
2606
2607    /// Similar to "send" but does not shutdown the channel if an error occurs.
2608    pub fn send_no_shutdown_on_err(self) -> Result<(), fidl::Error> {
2609        let _result = self.send_raw();
2610        self.drop_without_shutdown();
2611        _result
2612    }
2613
2614    fn send_raw(&self) -> Result<(), fidl::Error> {
2615        self.control_handle.inner.send::<fidl::encoding::EmptyPayload>(
2616            (),
2617            self.tx_id,
2618            0x7adb1c265a378e77,
2619            fidl::encoding::DynamicFlags::empty(),
2620        )
2621    }
2622}
2623
2624#[derive(Debug, Copy, Clone, Eq, PartialEq, Ord, PartialOrd, Hash)]
2625pub struct ClosedTargetEventReporterMarker;
2626
2627impl fidl::endpoints::ProtocolMarker for ClosedTargetEventReporterMarker {
2628    type Proxy = ClosedTargetEventReporterProxy;
2629    type RequestStream = ClosedTargetEventReporterRequestStream;
2630    #[cfg(target_os = "fuchsia")]
2631    type SynchronousProxy = ClosedTargetEventReporterSynchronousProxy;
2632
2633    const DEBUG_NAME: &'static str = "(anonymous) ClosedTargetEventReporter";
2634}
2635
2636pub trait ClosedTargetEventReporterProxyInterface: Send + Sync {
2637    fn r#report_event(&self, payload: &ClosedTargetEventReport) -> Result<(), fidl::Error>;
2638}
2639#[derive(Debug)]
2640#[cfg(target_os = "fuchsia")]
2641pub struct ClosedTargetEventReporterSynchronousProxy {
2642    client: fidl::client::sync::Client,
2643}
2644
2645#[cfg(target_os = "fuchsia")]
2646impl fidl::endpoints::SynchronousProxy for ClosedTargetEventReporterSynchronousProxy {
2647    type Proxy = ClosedTargetEventReporterProxy;
2648    type Protocol = ClosedTargetEventReporterMarker;
2649
2650    fn from_channel(inner: fidl::Channel) -> Self {
2651        Self::new(inner)
2652    }
2653
2654    fn into_channel(self) -> fidl::Channel {
2655        self.client.into_channel()
2656    }
2657
2658    fn as_channel(&self) -> &fidl::Channel {
2659        self.client.as_channel()
2660    }
2661}
2662
2663#[cfg(target_os = "fuchsia")]
2664impl ClosedTargetEventReporterSynchronousProxy {
2665    pub fn new(channel: fidl::Channel) -> Self {
2666        let protocol_name =
2667            <ClosedTargetEventReporterMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME;
2668        Self { client: fidl::client::sync::Client::new(channel, protocol_name) }
2669    }
2670
2671    pub fn into_channel(self) -> fidl::Channel {
2672        self.client.into_channel()
2673    }
2674
2675    /// Waits until an event arrives and returns it. It is safe for other
2676    /// threads to make concurrent requests while waiting for an event.
2677    pub fn wait_for_event(
2678        &self,
2679        deadline: zx::MonotonicInstant,
2680    ) -> Result<ClosedTargetEventReporterEvent, fidl::Error> {
2681        ClosedTargetEventReporterEvent::decode(self.client.wait_for_event(deadline)?)
2682    }
2683
2684    pub fn r#report_event(&self, mut payload: &ClosedTargetEventReport) -> Result<(), fidl::Error> {
2685        self.client.send::<ClosedTargetEventReport>(
2686            payload,
2687            0x63890e67649a846e,
2688            fidl::encoding::DynamicFlags::empty(),
2689        )
2690    }
2691}
2692
2693#[cfg(target_os = "fuchsia")]
2694impl From<ClosedTargetEventReporterSynchronousProxy> for zx::Handle {
2695    fn from(value: ClosedTargetEventReporterSynchronousProxy) -> Self {
2696        value.into_channel().into()
2697    }
2698}
2699
2700#[cfg(target_os = "fuchsia")]
2701impl From<fidl::Channel> for ClosedTargetEventReporterSynchronousProxy {
2702    fn from(value: fidl::Channel) -> Self {
2703        Self::new(value)
2704    }
2705}
2706
2707#[derive(Debug, Clone)]
2708pub struct ClosedTargetEventReporterProxy {
2709    client: fidl::client::Client<fidl::encoding::DefaultFuchsiaResourceDialect>,
2710}
2711
2712impl fidl::endpoints::Proxy for ClosedTargetEventReporterProxy {
2713    type Protocol = ClosedTargetEventReporterMarker;
2714
2715    fn from_channel(inner: ::fidl::AsyncChannel) -> Self {
2716        Self::new(inner)
2717    }
2718
2719    fn into_channel(self) -> Result<::fidl::AsyncChannel, Self> {
2720        self.client.into_channel().map_err(|client| Self { client })
2721    }
2722
2723    fn as_channel(&self) -> &::fidl::AsyncChannel {
2724        self.client.as_channel()
2725    }
2726}
2727
2728impl ClosedTargetEventReporterProxy {
2729    /// Create a new Proxy for fidl.clientsuite/ClosedTargetEventReporter.
2730    pub fn new(channel: ::fidl::AsyncChannel) -> Self {
2731        let protocol_name =
2732            <ClosedTargetEventReporterMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME;
2733        Self { client: fidl::client::Client::new(channel, protocol_name) }
2734    }
2735
2736    /// Get a Stream of events from the remote end of the protocol.
2737    ///
2738    /// # Panics
2739    ///
2740    /// Panics if the event stream was already taken.
2741    pub fn take_event_stream(&self) -> ClosedTargetEventReporterEventStream {
2742        ClosedTargetEventReporterEventStream { event_receiver: self.client.take_event_receiver() }
2743    }
2744
2745    pub fn r#report_event(&self, mut payload: &ClosedTargetEventReport) -> Result<(), fidl::Error> {
2746        ClosedTargetEventReporterProxyInterface::r#report_event(self, payload)
2747    }
2748}
2749
2750impl ClosedTargetEventReporterProxyInterface for ClosedTargetEventReporterProxy {
2751    fn r#report_event(&self, mut payload: &ClosedTargetEventReport) -> Result<(), fidl::Error> {
2752        self.client.send::<ClosedTargetEventReport>(
2753            payload,
2754            0x63890e67649a846e,
2755            fidl::encoding::DynamicFlags::empty(),
2756        )
2757    }
2758}
2759
2760pub struct ClosedTargetEventReporterEventStream {
2761    event_receiver: fidl::client::EventReceiver<fidl::encoding::DefaultFuchsiaResourceDialect>,
2762}
2763
2764impl std::marker::Unpin for ClosedTargetEventReporterEventStream {}
2765
2766impl futures::stream::FusedStream for ClosedTargetEventReporterEventStream {
2767    fn is_terminated(&self) -> bool {
2768        self.event_receiver.is_terminated()
2769    }
2770}
2771
2772impl futures::Stream for ClosedTargetEventReporterEventStream {
2773    type Item = Result<ClosedTargetEventReporterEvent, fidl::Error>;
2774
2775    fn poll_next(
2776        mut self: std::pin::Pin<&mut Self>,
2777        cx: &mut std::task::Context<'_>,
2778    ) -> std::task::Poll<Option<Self::Item>> {
2779        match futures::ready!(futures::stream::StreamExt::poll_next_unpin(
2780            &mut self.event_receiver,
2781            cx
2782        )?) {
2783            Some(buf) => std::task::Poll::Ready(Some(ClosedTargetEventReporterEvent::decode(buf))),
2784            None => std::task::Poll::Ready(None),
2785        }
2786    }
2787}
2788
2789#[derive(Debug)]
2790pub enum ClosedTargetEventReporterEvent {}
2791
2792impl ClosedTargetEventReporterEvent {
2793    /// Decodes a message buffer as a [`ClosedTargetEventReporterEvent`].
2794    fn decode(
2795        mut buf: <fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc,
2796    ) -> Result<ClosedTargetEventReporterEvent, fidl::Error> {
2797        let (bytes, _handles) = buf.split_mut();
2798        let (tx_header, _body_bytes) = fidl::encoding::decode_transaction_header(bytes)?;
2799        debug_assert_eq!(tx_header.tx_id, 0);
2800        match tx_header.ordinal {
2801            _ => Err(fidl::Error::UnknownOrdinal {
2802                ordinal: tx_header.ordinal,
2803                protocol_name:
2804                    <ClosedTargetEventReporterMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME,
2805            }),
2806        }
2807    }
2808}
2809
2810/// A Stream of incoming requests for fidl.clientsuite/ClosedTargetEventReporter.
2811pub struct ClosedTargetEventReporterRequestStream {
2812    inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
2813    is_terminated: bool,
2814}
2815
2816impl std::marker::Unpin for ClosedTargetEventReporterRequestStream {}
2817
2818impl futures::stream::FusedStream for ClosedTargetEventReporterRequestStream {
2819    fn is_terminated(&self) -> bool {
2820        self.is_terminated
2821    }
2822}
2823
2824impl fidl::endpoints::RequestStream for ClosedTargetEventReporterRequestStream {
2825    type Protocol = ClosedTargetEventReporterMarker;
2826    type ControlHandle = ClosedTargetEventReporterControlHandle;
2827
2828    fn from_channel(channel: ::fidl::AsyncChannel) -> Self {
2829        Self { inner: std::sync::Arc::new(fidl::ServeInner::new(channel)), is_terminated: false }
2830    }
2831
2832    fn control_handle(&self) -> Self::ControlHandle {
2833        ClosedTargetEventReporterControlHandle { inner: self.inner.clone() }
2834    }
2835
2836    fn into_inner(
2837        self,
2838    ) -> (::std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>, bool)
2839    {
2840        (self.inner, self.is_terminated)
2841    }
2842
2843    fn from_inner(
2844        inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
2845        is_terminated: bool,
2846    ) -> Self {
2847        Self { inner, is_terminated }
2848    }
2849}
2850
2851impl futures::Stream for ClosedTargetEventReporterRequestStream {
2852    type Item = Result<ClosedTargetEventReporterRequest, fidl::Error>;
2853
2854    fn poll_next(
2855        mut self: std::pin::Pin<&mut Self>,
2856        cx: &mut std::task::Context<'_>,
2857    ) -> std::task::Poll<Option<Self::Item>> {
2858        let this = &mut *self;
2859        if this.inner.check_shutdown(cx) {
2860            this.is_terminated = true;
2861            return std::task::Poll::Ready(None);
2862        }
2863        if this.is_terminated {
2864            panic!("polled ClosedTargetEventReporterRequestStream after completion");
2865        }
2866        fidl::encoding::with_tls_decode_buf::<_, fidl::encoding::DefaultFuchsiaResourceDialect>(
2867            |bytes, handles| {
2868                match this.inner.channel().read_etc(cx, bytes, handles) {
2869                    std::task::Poll::Ready(Ok(())) => {}
2870                    std::task::Poll::Pending => return std::task::Poll::Pending,
2871                    std::task::Poll::Ready(Err(zx_status::Status::PEER_CLOSED)) => {
2872                        this.is_terminated = true;
2873                        return std::task::Poll::Ready(None);
2874                    }
2875                    std::task::Poll::Ready(Err(e)) => {
2876                        return std::task::Poll::Ready(Some(Err(fidl::Error::ServerRequestRead(
2877                            e.into(),
2878                        ))))
2879                    }
2880                }
2881
2882                // A message has been received from the channel
2883                let (header, _body_bytes) = fidl::encoding::decode_transaction_header(bytes)?;
2884
2885                std::task::Poll::Ready(Some(match header.ordinal {
2886                0x63890e67649a846e => {
2887                    header.validate_request_tx_id(fidl::MethodType::OneWay)?;
2888                    let mut req = fidl::new_empty!(ClosedTargetEventReport, fidl::encoding::DefaultFuchsiaResourceDialect);
2889                    fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<ClosedTargetEventReport>(&header, _body_bytes, handles, &mut req)?;
2890                    let control_handle = ClosedTargetEventReporterControlHandle {
2891                        inner: this.inner.clone(),
2892                    };
2893                    Ok(ClosedTargetEventReporterRequest::ReportEvent {payload: req,
2894                        control_handle,
2895                    })
2896                }
2897                _ => Err(fidl::Error::UnknownOrdinal {
2898                    ordinal: header.ordinal,
2899                    protocol_name: <ClosedTargetEventReporterMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME,
2900                }),
2901            }))
2902            },
2903        )
2904    }
2905}
2906
2907#[derive(Debug)]
2908pub enum ClosedTargetEventReporterRequest {
2909    ReportEvent {
2910        payload: ClosedTargetEventReport,
2911        control_handle: ClosedTargetEventReporterControlHandle,
2912    },
2913}
2914
2915impl ClosedTargetEventReporterRequest {
2916    #[allow(irrefutable_let_patterns)]
2917    pub fn into_report_event(
2918        self,
2919    ) -> Option<(ClosedTargetEventReport, ClosedTargetEventReporterControlHandle)> {
2920        if let ClosedTargetEventReporterRequest::ReportEvent { payload, control_handle } = self {
2921            Some((payload, control_handle))
2922        } else {
2923            None
2924        }
2925    }
2926
2927    /// Name of the method defined in FIDL
2928    pub fn method_name(&self) -> &'static str {
2929        match *self {
2930            ClosedTargetEventReporterRequest::ReportEvent { .. } => "report_event",
2931        }
2932    }
2933}
2934
2935#[derive(Debug, Clone)]
2936pub struct ClosedTargetEventReporterControlHandle {
2937    inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
2938}
2939
2940impl fidl::endpoints::ControlHandle for ClosedTargetEventReporterControlHandle {
2941    fn shutdown(&self) {
2942        self.inner.shutdown()
2943    }
2944    fn shutdown_with_epitaph(&self, status: zx_status::Status) {
2945        self.inner.shutdown_with_epitaph(status)
2946    }
2947
2948    fn is_closed(&self) -> bool {
2949        self.inner.channel().is_closed()
2950    }
2951    fn on_closed(&self) -> fidl::OnSignalsRef<'_> {
2952        self.inner.channel().on_closed()
2953    }
2954
2955    #[cfg(target_os = "fuchsia")]
2956    fn signal_peer(
2957        &self,
2958        clear_mask: zx::Signals,
2959        set_mask: zx::Signals,
2960    ) -> Result<(), zx_status::Status> {
2961        use fidl::Peered;
2962        self.inner.channel().signal_peer(clear_mask, set_mask)
2963    }
2964}
2965
2966impl ClosedTargetEventReporterControlHandle {}
2967
2968#[derive(Debug, Copy, Clone, Eq, PartialEq, Ord, PartialOrd, Hash)]
2969pub struct OpenTargetMarker;
2970
2971impl fidl::endpoints::ProtocolMarker for OpenTargetMarker {
2972    type Proxy = OpenTargetProxy;
2973    type RequestStream = OpenTargetRequestStream;
2974    #[cfg(target_os = "fuchsia")]
2975    type SynchronousProxy = OpenTargetSynchronousProxy;
2976
2977    const DEBUG_NAME: &'static str = "(anonymous) OpenTarget";
2978}
2979pub type OpenTargetStrictTwoWayErrResult = Result<(), i32>;
2980pub type OpenTargetStrictTwoWayFieldsErrResult = Result<i32, i32>;
2981pub type OpenTargetFlexibleTwoWayErrResult = Result<(), i32>;
2982pub type OpenTargetFlexibleTwoWayFieldsErrResult = Result<i32, i32>;
2983
2984pub trait OpenTargetProxyInterface: Send + Sync {
2985    fn r#strict_one_way(&self) -> Result<(), fidl::Error>;
2986    fn r#flexible_one_way(&self) -> Result<(), fidl::Error>;
2987    type StrictTwoWayResponseFut: std::future::Future<Output = Result<(), fidl::Error>> + Send;
2988    fn r#strict_two_way(&self) -> Self::StrictTwoWayResponseFut;
2989    type StrictTwoWayFieldsResponseFut: std::future::Future<Output = Result<i32, fidl::Error>>
2990        + Send;
2991    fn r#strict_two_way_fields(&self) -> Self::StrictTwoWayFieldsResponseFut;
2992    type StrictTwoWayErrResponseFut: std::future::Future<Output = Result<OpenTargetStrictTwoWayErrResult, fidl::Error>>
2993        + Send;
2994    fn r#strict_two_way_err(&self) -> Self::StrictTwoWayErrResponseFut;
2995    type StrictTwoWayFieldsErrResponseFut: std::future::Future<Output = Result<OpenTargetStrictTwoWayFieldsErrResult, fidl::Error>>
2996        + Send;
2997    fn r#strict_two_way_fields_err(&self) -> Self::StrictTwoWayFieldsErrResponseFut;
2998    type FlexibleTwoWayResponseFut: std::future::Future<Output = Result<(), fidl::Error>> + Send;
2999    fn r#flexible_two_way(&self) -> Self::FlexibleTwoWayResponseFut;
3000    type FlexibleTwoWayFieldsResponseFut: std::future::Future<Output = Result<i32, fidl::Error>>
3001        + Send;
3002    fn r#flexible_two_way_fields(&self) -> Self::FlexibleTwoWayFieldsResponseFut;
3003    type FlexibleTwoWayErrResponseFut: std::future::Future<Output = Result<OpenTargetFlexibleTwoWayErrResult, fidl::Error>>
3004        + Send;
3005    fn r#flexible_two_way_err(&self) -> Self::FlexibleTwoWayErrResponseFut;
3006    type FlexibleTwoWayFieldsErrResponseFut: std::future::Future<Output = Result<OpenTargetFlexibleTwoWayFieldsErrResult, fidl::Error>>
3007        + Send;
3008    fn r#flexible_two_way_fields_err(&self) -> Self::FlexibleTwoWayFieldsErrResponseFut;
3009}
3010#[derive(Debug)]
3011#[cfg(target_os = "fuchsia")]
3012pub struct OpenTargetSynchronousProxy {
3013    client: fidl::client::sync::Client,
3014}
3015
3016#[cfg(target_os = "fuchsia")]
3017impl fidl::endpoints::SynchronousProxy for OpenTargetSynchronousProxy {
3018    type Proxy = OpenTargetProxy;
3019    type Protocol = OpenTargetMarker;
3020
3021    fn from_channel(inner: fidl::Channel) -> Self {
3022        Self::new(inner)
3023    }
3024
3025    fn into_channel(self) -> fidl::Channel {
3026        self.client.into_channel()
3027    }
3028
3029    fn as_channel(&self) -> &fidl::Channel {
3030        self.client.as_channel()
3031    }
3032}
3033
3034#[cfg(target_os = "fuchsia")]
3035impl OpenTargetSynchronousProxy {
3036    pub fn new(channel: fidl::Channel) -> Self {
3037        let protocol_name = <OpenTargetMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME;
3038        Self { client: fidl::client::sync::Client::new(channel, protocol_name) }
3039    }
3040
3041    pub fn into_channel(self) -> fidl::Channel {
3042        self.client.into_channel()
3043    }
3044
3045    /// Waits until an event arrives and returns it. It is safe for other
3046    /// threads to make concurrent requests while waiting for an event.
3047    pub fn wait_for_event(
3048        &self,
3049        deadline: zx::MonotonicInstant,
3050    ) -> Result<OpenTargetEvent, fidl::Error> {
3051        OpenTargetEvent::decode(self.client.wait_for_event(deadline)?)
3052    }
3053
3054    pub fn r#strict_one_way(&self) -> Result<(), fidl::Error> {
3055        self.client.send::<fidl::encoding::EmptyPayload>(
3056            (),
3057            0x6db0bc21c4aae764,
3058            fidl::encoding::DynamicFlags::empty(),
3059        )
3060    }
3061
3062    pub fn r#flexible_one_way(&self) -> Result<(), fidl::Error> {
3063        self.client.send::<fidl::encoding::EmptyPayload>(
3064            (),
3065            0xf894a7eb9cc29fc,
3066            fidl::encoding::DynamicFlags::FLEXIBLE,
3067        )
3068    }
3069
3070    pub fn r#strict_two_way(&self, ___deadline: zx::MonotonicInstant) -> Result<(), fidl::Error> {
3071        let _response =
3072            self.client.send_query::<fidl::encoding::EmptyPayload, fidl::encoding::EmptyPayload>(
3073                (),
3074                0xdcf4cef19a1c542,
3075                fidl::encoding::DynamicFlags::empty(),
3076                ___deadline,
3077            )?;
3078        Ok(_response)
3079    }
3080
3081    pub fn r#strict_two_way_fields(
3082        &self,
3083        ___deadline: zx::MonotonicInstant,
3084    ) -> Result<i32, fidl::Error> {
3085        let _response = self.client.send_query::<fidl::encoding::EmptyPayload, NonEmptyPayload>(
3086            (),
3087            0x79c7a7803c45e2e3,
3088            fidl::encoding::DynamicFlags::empty(),
3089            ___deadline,
3090        )?;
3091        Ok(_response.some_field)
3092    }
3093
3094    pub fn r#strict_two_way_err(
3095        &self,
3096        ___deadline: zx::MonotonicInstant,
3097    ) -> Result<OpenTargetStrictTwoWayErrResult, fidl::Error> {
3098        let _response = self.client.send_query::<
3099            fidl::encoding::EmptyPayload,
3100            fidl::encoding::ResultType<fidl::encoding::EmptyStruct, i32>,
3101        >(
3102            (),
3103            0x54259ed6c262fe88,
3104            fidl::encoding::DynamicFlags::empty(),
3105            ___deadline,
3106        )?;
3107        Ok(_response.map(|x| x))
3108    }
3109
3110    pub fn r#strict_two_way_fields_err(
3111        &self,
3112        ___deadline: zx::MonotonicInstant,
3113    ) -> Result<OpenTargetStrictTwoWayFieldsErrResult, fidl::Error> {
3114        let _response = self.client.send_query::<
3115            fidl::encoding::EmptyPayload,
3116            fidl::encoding::ResultType<NonEmptyPayload, i32>,
3117        >(
3118            (),
3119            0x7dbaa8538b552711,
3120            fidl::encoding::DynamicFlags::empty(),
3121            ___deadline,
3122        )?;
3123        Ok(_response.map(|x| x.some_field))
3124    }
3125
3126    pub fn r#flexible_two_way(&self, ___deadline: zx::MonotonicInstant) -> Result<(), fidl::Error> {
3127        let _response = self.client.send_query::<
3128            fidl::encoding::EmptyPayload,
3129            fidl::encoding::FlexibleType<fidl::encoding::EmptyStruct>,
3130        >(
3131            (),
3132            0x66552e68b99a0587,
3133            fidl::encoding::DynamicFlags::FLEXIBLE,
3134            ___deadline,
3135        )?
3136        .into_result::<OpenTargetMarker>("flexible_two_way")?;
3137        Ok(_response)
3138    }
3139
3140    pub fn r#flexible_two_way_fields(
3141        &self,
3142        ___deadline: zx::MonotonicInstant,
3143    ) -> Result<i32, fidl::Error> {
3144        let _response = self.client.send_query::<
3145            fidl::encoding::EmptyPayload,
3146            fidl::encoding::FlexibleType<NonEmptyPayload>,
3147        >(
3148            (),
3149            0x38b95648ac4e2ae4,
3150            fidl::encoding::DynamicFlags::FLEXIBLE,
3151            ___deadline,
3152        )?
3153        .into_result::<OpenTargetMarker>("flexible_two_way_fields")?;
3154        Ok(_response.some_field)
3155    }
3156
3157    pub fn r#flexible_two_way_err(
3158        &self,
3159        ___deadline: zx::MonotonicInstant,
3160    ) -> Result<OpenTargetFlexibleTwoWayErrResult, fidl::Error> {
3161        let _response = self.client.send_query::<
3162            fidl::encoding::EmptyPayload,
3163            fidl::encoding::FlexibleResultType<fidl::encoding::EmptyStruct, i32>,
3164        >(
3165            (),
3166            0x6e144c6e0cf2147a,
3167            fidl::encoding::DynamicFlags::FLEXIBLE,
3168            ___deadline,
3169        )?
3170        .into_result::<OpenTargetMarker>("flexible_two_way_err")?;
3171        Ok(_response.map(|x| x))
3172    }
3173
3174    pub fn r#flexible_two_way_fields_err(
3175        &self,
3176        ___deadline: zx::MonotonicInstant,
3177    ) -> Result<OpenTargetFlexibleTwoWayFieldsErrResult, fidl::Error> {
3178        let _response = self.client.send_query::<
3179            fidl::encoding::EmptyPayload,
3180            fidl::encoding::FlexibleResultType<NonEmptyPayload, i32>,
3181        >(
3182            (),
3183            0xe494147cda8024a,
3184            fidl::encoding::DynamicFlags::FLEXIBLE,
3185            ___deadline,
3186        )?
3187        .into_result::<OpenTargetMarker>("flexible_two_way_fields_err")?;
3188        Ok(_response.map(|x| x.some_field))
3189    }
3190}
3191
3192#[cfg(target_os = "fuchsia")]
3193impl From<OpenTargetSynchronousProxy> for zx::Handle {
3194    fn from(value: OpenTargetSynchronousProxy) -> Self {
3195        value.into_channel().into()
3196    }
3197}
3198
3199#[cfg(target_os = "fuchsia")]
3200impl From<fidl::Channel> for OpenTargetSynchronousProxy {
3201    fn from(value: fidl::Channel) -> Self {
3202        Self::new(value)
3203    }
3204}
3205
3206#[derive(Debug, Clone)]
3207pub struct OpenTargetProxy {
3208    client: fidl::client::Client<fidl::encoding::DefaultFuchsiaResourceDialect>,
3209}
3210
3211impl fidl::endpoints::Proxy for OpenTargetProxy {
3212    type Protocol = OpenTargetMarker;
3213
3214    fn from_channel(inner: ::fidl::AsyncChannel) -> Self {
3215        Self::new(inner)
3216    }
3217
3218    fn into_channel(self) -> Result<::fidl::AsyncChannel, Self> {
3219        self.client.into_channel().map_err(|client| Self { client })
3220    }
3221
3222    fn as_channel(&self) -> &::fidl::AsyncChannel {
3223        self.client.as_channel()
3224    }
3225}
3226
3227impl OpenTargetProxy {
3228    /// Create a new Proxy for fidl.clientsuite/OpenTarget.
3229    pub fn new(channel: ::fidl::AsyncChannel) -> Self {
3230        let protocol_name = <OpenTargetMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME;
3231        Self { client: fidl::client::Client::new(channel, protocol_name) }
3232    }
3233
3234    /// Get a Stream of events from the remote end of the protocol.
3235    ///
3236    /// # Panics
3237    ///
3238    /// Panics if the event stream was already taken.
3239    pub fn take_event_stream(&self) -> OpenTargetEventStream {
3240        OpenTargetEventStream { event_receiver: self.client.take_event_receiver() }
3241    }
3242
3243    pub fn r#strict_one_way(&self) -> Result<(), fidl::Error> {
3244        OpenTargetProxyInterface::r#strict_one_way(self)
3245    }
3246
3247    pub fn r#flexible_one_way(&self) -> Result<(), fidl::Error> {
3248        OpenTargetProxyInterface::r#flexible_one_way(self)
3249    }
3250
3251    pub fn r#strict_two_way(
3252        &self,
3253    ) -> fidl::client::QueryResponseFut<(), fidl::encoding::DefaultFuchsiaResourceDialect> {
3254        OpenTargetProxyInterface::r#strict_two_way(self)
3255    }
3256
3257    pub fn r#strict_two_way_fields(
3258        &self,
3259    ) -> fidl::client::QueryResponseFut<i32, fidl::encoding::DefaultFuchsiaResourceDialect> {
3260        OpenTargetProxyInterface::r#strict_two_way_fields(self)
3261    }
3262
3263    pub fn r#strict_two_way_err(
3264        &self,
3265    ) -> fidl::client::QueryResponseFut<
3266        OpenTargetStrictTwoWayErrResult,
3267        fidl::encoding::DefaultFuchsiaResourceDialect,
3268    > {
3269        OpenTargetProxyInterface::r#strict_two_way_err(self)
3270    }
3271
3272    pub fn r#strict_two_way_fields_err(
3273        &self,
3274    ) -> fidl::client::QueryResponseFut<
3275        OpenTargetStrictTwoWayFieldsErrResult,
3276        fidl::encoding::DefaultFuchsiaResourceDialect,
3277    > {
3278        OpenTargetProxyInterface::r#strict_two_way_fields_err(self)
3279    }
3280
3281    pub fn r#flexible_two_way(
3282        &self,
3283    ) -> fidl::client::QueryResponseFut<(), fidl::encoding::DefaultFuchsiaResourceDialect> {
3284        OpenTargetProxyInterface::r#flexible_two_way(self)
3285    }
3286
3287    pub fn r#flexible_two_way_fields(
3288        &self,
3289    ) -> fidl::client::QueryResponseFut<i32, fidl::encoding::DefaultFuchsiaResourceDialect> {
3290        OpenTargetProxyInterface::r#flexible_two_way_fields(self)
3291    }
3292
3293    pub fn r#flexible_two_way_err(
3294        &self,
3295    ) -> fidl::client::QueryResponseFut<
3296        OpenTargetFlexibleTwoWayErrResult,
3297        fidl::encoding::DefaultFuchsiaResourceDialect,
3298    > {
3299        OpenTargetProxyInterface::r#flexible_two_way_err(self)
3300    }
3301
3302    pub fn r#flexible_two_way_fields_err(
3303        &self,
3304    ) -> fidl::client::QueryResponseFut<
3305        OpenTargetFlexibleTwoWayFieldsErrResult,
3306        fidl::encoding::DefaultFuchsiaResourceDialect,
3307    > {
3308        OpenTargetProxyInterface::r#flexible_two_way_fields_err(self)
3309    }
3310}
3311
3312impl OpenTargetProxyInterface for OpenTargetProxy {
3313    fn r#strict_one_way(&self) -> Result<(), fidl::Error> {
3314        self.client.send::<fidl::encoding::EmptyPayload>(
3315            (),
3316            0x6db0bc21c4aae764,
3317            fidl::encoding::DynamicFlags::empty(),
3318        )
3319    }
3320
3321    fn r#flexible_one_way(&self) -> Result<(), fidl::Error> {
3322        self.client.send::<fidl::encoding::EmptyPayload>(
3323            (),
3324            0xf894a7eb9cc29fc,
3325            fidl::encoding::DynamicFlags::FLEXIBLE,
3326        )
3327    }
3328
3329    type StrictTwoWayResponseFut =
3330        fidl::client::QueryResponseFut<(), fidl::encoding::DefaultFuchsiaResourceDialect>;
3331    fn r#strict_two_way(&self) -> Self::StrictTwoWayResponseFut {
3332        fn _decode(
3333            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
3334        ) -> Result<(), fidl::Error> {
3335            let _response = fidl::client::decode_transaction_body::<
3336                fidl::encoding::EmptyPayload,
3337                fidl::encoding::DefaultFuchsiaResourceDialect,
3338                0xdcf4cef19a1c542,
3339            >(_buf?)?;
3340            Ok(_response)
3341        }
3342        self.client.send_query_and_decode::<fidl::encoding::EmptyPayload, ()>(
3343            (),
3344            0xdcf4cef19a1c542,
3345            fidl::encoding::DynamicFlags::empty(),
3346            _decode,
3347        )
3348    }
3349
3350    type StrictTwoWayFieldsResponseFut =
3351        fidl::client::QueryResponseFut<i32, fidl::encoding::DefaultFuchsiaResourceDialect>;
3352    fn r#strict_two_way_fields(&self) -> Self::StrictTwoWayFieldsResponseFut {
3353        fn _decode(
3354            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
3355        ) -> Result<i32, fidl::Error> {
3356            let _response = fidl::client::decode_transaction_body::<
3357                NonEmptyPayload,
3358                fidl::encoding::DefaultFuchsiaResourceDialect,
3359                0x79c7a7803c45e2e3,
3360            >(_buf?)?;
3361            Ok(_response.some_field)
3362        }
3363        self.client.send_query_and_decode::<fidl::encoding::EmptyPayload, i32>(
3364            (),
3365            0x79c7a7803c45e2e3,
3366            fidl::encoding::DynamicFlags::empty(),
3367            _decode,
3368        )
3369    }
3370
3371    type StrictTwoWayErrResponseFut = fidl::client::QueryResponseFut<
3372        OpenTargetStrictTwoWayErrResult,
3373        fidl::encoding::DefaultFuchsiaResourceDialect,
3374    >;
3375    fn r#strict_two_way_err(&self) -> Self::StrictTwoWayErrResponseFut {
3376        fn _decode(
3377            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
3378        ) -> Result<OpenTargetStrictTwoWayErrResult, fidl::Error> {
3379            let _response = fidl::client::decode_transaction_body::<
3380                fidl::encoding::ResultType<fidl::encoding::EmptyStruct, i32>,
3381                fidl::encoding::DefaultFuchsiaResourceDialect,
3382                0x54259ed6c262fe88,
3383            >(_buf?)?;
3384            Ok(_response.map(|x| x))
3385        }
3386        self.client
3387            .send_query_and_decode::<fidl::encoding::EmptyPayload, OpenTargetStrictTwoWayErrResult>(
3388                (),
3389                0x54259ed6c262fe88,
3390                fidl::encoding::DynamicFlags::empty(),
3391                _decode,
3392            )
3393    }
3394
3395    type StrictTwoWayFieldsErrResponseFut = fidl::client::QueryResponseFut<
3396        OpenTargetStrictTwoWayFieldsErrResult,
3397        fidl::encoding::DefaultFuchsiaResourceDialect,
3398    >;
3399    fn r#strict_two_way_fields_err(&self) -> Self::StrictTwoWayFieldsErrResponseFut {
3400        fn _decode(
3401            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
3402        ) -> Result<OpenTargetStrictTwoWayFieldsErrResult, fidl::Error> {
3403            let _response = fidl::client::decode_transaction_body::<
3404                fidl::encoding::ResultType<NonEmptyPayload, i32>,
3405                fidl::encoding::DefaultFuchsiaResourceDialect,
3406                0x7dbaa8538b552711,
3407            >(_buf?)?;
3408            Ok(_response.map(|x| x.some_field))
3409        }
3410        self.client.send_query_and_decode::<
3411            fidl::encoding::EmptyPayload,
3412            OpenTargetStrictTwoWayFieldsErrResult,
3413        >(
3414            (),
3415            0x7dbaa8538b552711,
3416            fidl::encoding::DynamicFlags::empty(),
3417            _decode,
3418        )
3419    }
3420
3421    type FlexibleTwoWayResponseFut =
3422        fidl::client::QueryResponseFut<(), fidl::encoding::DefaultFuchsiaResourceDialect>;
3423    fn r#flexible_two_way(&self) -> Self::FlexibleTwoWayResponseFut {
3424        fn _decode(
3425            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
3426        ) -> Result<(), fidl::Error> {
3427            let _response = fidl::client::decode_transaction_body::<
3428                fidl::encoding::FlexibleType<fidl::encoding::EmptyStruct>,
3429                fidl::encoding::DefaultFuchsiaResourceDialect,
3430                0x66552e68b99a0587,
3431            >(_buf?)?
3432            .into_result::<OpenTargetMarker>("flexible_two_way")?;
3433            Ok(_response)
3434        }
3435        self.client.send_query_and_decode::<fidl::encoding::EmptyPayload, ()>(
3436            (),
3437            0x66552e68b99a0587,
3438            fidl::encoding::DynamicFlags::FLEXIBLE,
3439            _decode,
3440        )
3441    }
3442
3443    type FlexibleTwoWayFieldsResponseFut =
3444        fidl::client::QueryResponseFut<i32, fidl::encoding::DefaultFuchsiaResourceDialect>;
3445    fn r#flexible_two_way_fields(&self) -> Self::FlexibleTwoWayFieldsResponseFut {
3446        fn _decode(
3447            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
3448        ) -> Result<i32, fidl::Error> {
3449            let _response = fidl::client::decode_transaction_body::<
3450                fidl::encoding::FlexibleType<NonEmptyPayload>,
3451                fidl::encoding::DefaultFuchsiaResourceDialect,
3452                0x38b95648ac4e2ae4,
3453            >(_buf?)?
3454            .into_result::<OpenTargetMarker>("flexible_two_way_fields")?;
3455            Ok(_response.some_field)
3456        }
3457        self.client.send_query_and_decode::<fidl::encoding::EmptyPayload, i32>(
3458            (),
3459            0x38b95648ac4e2ae4,
3460            fidl::encoding::DynamicFlags::FLEXIBLE,
3461            _decode,
3462        )
3463    }
3464
3465    type FlexibleTwoWayErrResponseFut = fidl::client::QueryResponseFut<
3466        OpenTargetFlexibleTwoWayErrResult,
3467        fidl::encoding::DefaultFuchsiaResourceDialect,
3468    >;
3469    fn r#flexible_two_way_err(&self) -> Self::FlexibleTwoWayErrResponseFut {
3470        fn _decode(
3471            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
3472        ) -> Result<OpenTargetFlexibleTwoWayErrResult, fidl::Error> {
3473            let _response = fidl::client::decode_transaction_body::<
3474                fidl::encoding::FlexibleResultType<fidl::encoding::EmptyStruct, i32>,
3475                fidl::encoding::DefaultFuchsiaResourceDialect,
3476                0x6e144c6e0cf2147a,
3477            >(_buf?)?
3478            .into_result::<OpenTargetMarker>("flexible_two_way_err")?;
3479            Ok(_response.map(|x| x))
3480        }
3481        self.client.send_query_and_decode::<
3482            fidl::encoding::EmptyPayload,
3483            OpenTargetFlexibleTwoWayErrResult,
3484        >(
3485            (),
3486            0x6e144c6e0cf2147a,
3487            fidl::encoding::DynamicFlags::FLEXIBLE,
3488            _decode,
3489        )
3490    }
3491
3492    type FlexibleTwoWayFieldsErrResponseFut = fidl::client::QueryResponseFut<
3493        OpenTargetFlexibleTwoWayFieldsErrResult,
3494        fidl::encoding::DefaultFuchsiaResourceDialect,
3495    >;
3496    fn r#flexible_two_way_fields_err(&self) -> Self::FlexibleTwoWayFieldsErrResponseFut {
3497        fn _decode(
3498            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
3499        ) -> Result<OpenTargetFlexibleTwoWayFieldsErrResult, fidl::Error> {
3500            let _response = fidl::client::decode_transaction_body::<
3501                fidl::encoding::FlexibleResultType<NonEmptyPayload, i32>,
3502                fidl::encoding::DefaultFuchsiaResourceDialect,
3503                0xe494147cda8024a,
3504            >(_buf?)?
3505            .into_result::<OpenTargetMarker>("flexible_two_way_fields_err")?;
3506            Ok(_response.map(|x| x.some_field))
3507        }
3508        self.client.send_query_and_decode::<
3509            fidl::encoding::EmptyPayload,
3510            OpenTargetFlexibleTwoWayFieldsErrResult,
3511        >(
3512            (),
3513            0xe494147cda8024a,
3514            fidl::encoding::DynamicFlags::FLEXIBLE,
3515            _decode,
3516        )
3517    }
3518}
3519
3520pub struct OpenTargetEventStream {
3521    event_receiver: fidl::client::EventReceiver<fidl::encoding::DefaultFuchsiaResourceDialect>,
3522}
3523
3524impl std::marker::Unpin for OpenTargetEventStream {}
3525
3526impl futures::stream::FusedStream for OpenTargetEventStream {
3527    fn is_terminated(&self) -> bool {
3528        self.event_receiver.is_terminated()
3529    }
3530}
3531
3532impl futures::Stream for OpenTargetEventStream {
3533    type Item = Result<OpenTargetEvent, fidl::Error>;
3534
3535    fn poll_next(
3536        mut self: std::pin::Pin<&mut Self>,
3537        cx: &mut std::task::Context<'_>,
3538    ) -> std::task::Poll<Option<Self::Item>> {
3539        match futures::ready!(futures::stream::StreamExt::poll_next_unpin(
3540            &mut self.event_receiver,
3541            cx
3542        )?) {
3543            Some(buf) => std::task::Poll::Ready(Some(OpenTargetEvent::decode(buf))),
3544            None => std::task::Poll::Ready(None),
3545        }
3546    }
3547}
3548
3549#[derive(Debug)]
3550pub enum OpenTargetEvent {
3551    StrictEvent {},
3552    FlexibleEvent {},
3553    #[non_exhaustive]
3554    _UnknownEvent {
3555        /// Ordinal of the event that was sent.
3556        ordinal: u64,
3557    },
3558}
3559
3560impl OpenTargetEvent {
3561    #[allow(irrefutable_let_patterns)]
3562    pub fn into_strict_event(self) -> Option<()> {
3563        if let OpenTargetEvent::StrictEvent {} = self {
3564            Some(())
3565        } else {
3566            None
3567        }
3568    }
3569    #[allow(irrefutable_let_patterns)]
3570    pub fn into_flexible_event(self) -> Option<()> {
3571        if let OpenTargetEvent::FlexibleEvent {} = self {
3572            Some(())
3573        } else {
3574            None
3575        }
3576    }
3577
3578    /// Decodes a message buffer as a [`OpenTargetEvent`].
3579    fn decode(
3580        mut buf: <fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc,
3581    ) -> Result<OpenTargetEvent, fidl::Error> {
3582        let (bytes, _handles) = buf.split_mut();
3583        let (tx_header, _body_bytes) = fidl::encoding::decode_transaction_header(bytes)?;
3584        debug_assert_eq!(tx_header.tx_id, 0);
3585        match tx_header.ordinal {
3586            0x2b291d74321e77a0 => {
3587                let mut out = fidl::new_empty!(
3588                    fidl::encoding::EmptyPayload,
3589                    fidl::encoding::DefaultFuchsiaResourceDialect
3590                );
3591                fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&tx_header, _body_bytes, _handles, &mut out)?;
3592                Ok((OpenTargetEvent::StrictEvent {}))
3593            }
3594            0x50d4688058898898 => {
3595                let mut out = fidl::new_empty!(
3596                    fidl::encoding::EmptyPayload,
3597                    fidl::encoding::DefaultFuchsiaResourceDialect
3598                );
3599                fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&tx_header, _body_bytes, _handles, &mut out)?;
3600                Ok((OpenTargetEvent::FlexibleEvent {}))
3601            }
3602            _ if tx_header.dynamic_flags().contains(fidl::encoding::DynamicFlags::FLEXIBLE) => {
3603                Ok(OpenTargetEvent::_UnknownEvent { ordinal: tx_header.ordinal })
3604            }
3605            _ => Err(fidl::Error::UnknownOrdinal {
3606                ordinal: tx_header.ordinal,
3607                protocol_name: <OpenTargetMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME,
3608            }),
3609        }
3610    }
3611}
3612
3613/// A Stream of incoming requests for fidl.clientsuite/OpenTarget.
3614pub struct OpenTargetRequestStream {
3615    inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
3616    is_terminated: bool,
3617}
3618
3619impl std::marker::Unpin for OpenTargetRequestStream {}
3620
3621impl futures::stream::FusedStream for OpenTargetRequestStream {
3622    fn is_terminated(&self) -> bool {
3623        self.is_terminated
3624    }
3625}
3626
3627impl fidl::endpoints::RequestStream for OpenTargetRequestStream {
3628    type Protocol = OpenTargetMarker;
3629    type ControlHandle = OpenTargetControlHandle;
3630
3631    fn from_channel(channel: ::fidl::AsyncChannel) -> Self {
3632        Self { inner: std::sync::Arc::new(fidl::ServeInner::new(channel)), is_terminated: false }
3633    }
3634
3635    fn control_handle(&self) -> Self::ControlHandle {
3636        OpenTargetControlHandle { inner: self.inner.clone() }
3637    }
3638
3639    fn into_inner(
3640        self,
3641    ) -> (::std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>, bool)
3642    {
3643        (self.inner, self.is_terminated)
3644    }
3645
3646    fn from_inner(
3647        inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
3648        is_terminated: bool,
3649    ) -> Self {
3650        Self { inner, is_terminated }
3651    }
3652}
3653
3654impl futures::Stream for OpenTargetRequestStream {
3655    type Item = Result<OpenTargetRequest, fidl::Error>;
3656
3657    fn poll_next(
3658        mut self: std::pin::Pin<&mut Self>,
3659        cx: &mut std::task::Context<'_>,
3660    ) -> std::task::Poll<Option<Self::Item>> {
3661        let this = &mut *self;
3662        if this.inner.check_shutdown(cx) {
3663            this.is_terminated = true;
3664            return std::task::Poll::Ready(None);
3665        }
3666        if this.is_terminated {
3667            panic!("polled OpenTargetRequestStream after completion");
3668        }
3669        fidl::encoding::with_tls_decode_buf::<_, fidl::encoding::DefaultFuchsiaResourceDialect>(
3670            |bytes, handles| {
3671                match this.inner.channel().read_etc(cx, bytes, handles) {
3672                    std::task::Poll::Ready(Ok(())) => {}
3673                    std::task::Poll::Pending => return std::task::Poll::Pending,
3674                    std::task::Poll::Ready(Err(zx_status::Status::PEER_CLOSED)) => {
3675                        this.is_terminated = true;
3676                        return std::task::Poll::Ready(None);
3677                    }
3678                    std::task::Poll::Ready(Err(e)) => {
3679                        return std::task::Poll::Ready(Some(Err(fidl::Error::ServerRequestRead(
3680                            e.into(),
3681                        ))))
3682                    }
3683                }
3684
3685                // A message has been received from the channel
3686                let (header, _body_bytes) = fidl::encoding::decode_transaction_header(bytes)?;
3687
3688                std::task::Poll::Ready(Some(match header.ordinal {
3689                    0x6db0bc21c4aae764 => {
3690                        header.validate_request_tx_id(fidl::MethodType::OneWay)?;
3691                        let mut req = fidl::new_empty!(
3692                            fidl::encoding::EmptyPayload,
3693                            fidl::encoding::DefaultFuchsiaResourceDialect
3694                        );
3695                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&header, _body_bytes, handles, &mut req)?;
3696                        let control_handle = OpenTargetControlHandle { inner: this.inner.clone() };
3697                        Ok(OpenTargetRequest::StrictOneWay { control_handle })
3698                    }
3699                    0xf894a7eb9cc29fc => {
3700                        header.validate_request_tx_id(fidl::MethodType::OneWay)?;
3701                        let mut req = fidl::new_empty!(
3702                            fidl::encoding::EmptyPayload,
3703                            fidl::encoding::DefaultFuchsiaResourceDialect
3704                        );
3705                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&header, _body_bytes, handles, &mut req)?;
3706                        let control_handle = OpenTargetControlHandle { inner: this.inner.clone() };
3707                        Ok(OpenTargetRequest::FlexibleOneWay { control_handle })
3708                    }
3709                    0xdcf4cef19a1c542 => {
3710                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
3711                        let mut req = fidl::new_empty!(
3712                            fidl::encoding::EmptyPayload,
3713                            fidl::encoding::DefaultFuchsiaResourceDialect
3714                        );
3715                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&header, _body_bytes, handles, &mut req)?;
3716                        let control_handle = OpenTargetControlHandle { inner: this.inner.clone() };
3717                        Ok(OpenTargetRequest::StrictTwoWay {
3718                            responder: OpenTargetStrictTwoWayResponder {
3719                                control_handle: std::mem::ManuallyDrop::new(control_handle),
3720                                tx_id: header.tx_id,
3721                            },
3722                        })
3723                    }
3724                    0x79c7a7803c45e2e3 => {
3725                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
3726                        let mut req = fidl::new_empty!(
3727                            fidl::encoding::EmptyPayload,
3728                            fidl::encoding::DefaultFuchsiaResourceDialect
3729                        );
3730                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&header, _body_bytes, handles, &mut req)?;
3731                        let control_handle = OpenTargetControlHandle { inner: this.inner.clone() };
3732                        Ok(OpenTargetRequest::StrictTwoWayFields {
3733                            responder: OpenTargetStrictTwoWayFieldsResponder {
3734                                control_handle: std::mem::ManuallyDrop::new(control_handle),
3735                                tx_id: header.tx_id,
3736                            },
3737                        })
3738                    }
3739                    0x54259ed6c262fe88 => {
3740                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
3741                        let mut req = fidl::new_empty!(
3742                            fidl::encoding::EmptyPayload,
3743                            fidl::encoding::DefaultFuchsiaResourceDialect
3744                        );
3745                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&header, _body_bytes, handles, &mut req)?;
3746                        let control_handle = OpenTargetControlHandle { inner: this.inner.clone() };
3747                        Ok(OpenTargetRequest::StrictTwoWayErr {
3748                            responder: OpenTargetStrictTwoWayErrResponder {
3749                                control_handle: std::mem::ManuallyDrop::new(control_handle),
3750                                tx_id: header.tx_id,
3751                            },
3752                        })
3753                    }
3754                    0x7dbaa8538b552711 => {
3755                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
3756                        let mut req = fidl::new_empty!(
3757                            fidl::encoding::EmptyPayload,
3758                            fidl::encoding::DefaultFuchsiaResourceDialect
3759                        );
3760                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&header, _body_bytes, handles, &mut req)?;
3761                        let control_handle = OpenTargetControlHandle { inner: this.inner.clone() };
3762                        Ok(OpenTargetRequest::StrictTwoWayFieldsErr {
3763                            responder: OpenTargetStrictTwoWayFieldsErrResponder {
3764                                control_handle: std::mem::ManuallyDrop::new(control_handle),
3765                                tx_id: header.tx_id,
3766                            },
3767                        })
3768                    }
3769                    0x66552e68b99a0587 => {
3770                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
3771                        let mut req = fidl::new_empty!(
3772                            fidl::encoding::EmptyPayload,
3773                            fidl::encoding::DefaultFuchsiaResourceDialect
3774                        );
3775                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&header, _body_bytes, handles, &mut req)?;
3776                        let control_handle = OpenTargetControlHandle { inner: this.inner.clone() };
3777                        Ok(OpenTargetRequest::FlexibleTwoWay {
3778                            responder: OpenTargetFlexibleTwoWayResponder {
3779                                control_handle: std::mem::ManuallyDrop::new(control_handle),
3780                                tx_id: header.tx_id,
3781                            },
3782                        })
3783                    }
3784                    0x38b95648ac4e2ae4 => {
3785                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
3786                        let mut req = fidl::new_empty!(
3787                            fidl::encoding::EmptyPayload,
3788                            fidl::encoding::DefaultFuchsiaResourceDialect
3789                        );
3790                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&header, _body_bytes, handles, &mut req)?;
3791                        let control_handle = OpenTargetControlHandle { inner: this.inner.clone() };
3792                        Ok(OpenTargetRequest::FlexibleTwoWayFields {
3793                            responder: OpenTargetFlexibleTwoWayFieldsResponder {
3794                                control_handle: std::mem::ManuallyDrop::new(control_handle),
3795                                tx_id: header.tx_id,
3796                            },
3797                        })
3798                    }
3799                    0x6e144c6e0cf2147a => {
3800                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
3801                        let mut req = fidl::new_empty!(
3802                            fidl::encoding::EmptyPayload,
3803                            fidl::encoding::DefaultFuchsiaResourceDialect
3804                        );
3805                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&header, _body_bytes, handles, &mut req)?;
3806                        let control_handle = OpenTargetControlHandle { inner: this.inner.clone() };
3807                        Ok(OpenTargetRequest::FlexibleTwoWayErr {
3808                            responder: OpenTargetFlexibleTwoWayErrResponder {
3809                                control_handle: std::mem::ManuallyDrop::new(control_handle),
3810                                tx_id: header.tx_id,
3811                            },
3812                        })
3813                    }
3814                    0xe494147cda8024a => {
3815                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
3816                        let mut req = fidl::new_empty!(
3817                            fidl::encoding::EmptyPayload,
3818                            fidl::encoding::DefaultFuchsiaResourceDialect
3819                        );
3820                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&header, _body_bytes, handles, &mut req)?;
3821                        let control_handle = OpenTargetControlHandle { inner: this.inner.clone() };
3822                        Ok(OpenTargetRequest::FlexibleTwoWayFieldsErr {
3823                            responder: OpenTargetFlexibleTwoWayFieldsErrResponder {
3824                                control_handle: std::mem::ManuallyDrop::new(control_handle),
3825                                tx_id: header.tx_id,
3826                            },
3827                        })
3828                    }
3829                    _ if header.tx_id == 0
3830                        && header
3831                            .dynamic_flags()
3832                            .contains(fidl::encoding::DynamicFlags::FLEXIBLE) =>
3833                    {
3834                        Ok(OpenTargetRequest::_UnknownMethod {
3835                            ordinal: header.ordinal,
3836                            control_handle: OpenTargetControlHandle { inner: this.inner.clone() },
3837                            method_type: fidl::MethodType::OneWay,
3838                        })
3839                    }
3840                    _ if header
3841                        .dynamic_flags()
3842                        .contains(fidl::encoding::DynamicFlags::FLEXIBLE) =>
3843                    {
3844                        this.inner.send_framework_err(
3845                            fidl::encoding::FrameworkErr::UnknownMethod,
3846                            header.tx_id,
3847                            header.ordinal,
3848                            header.dynamic_flags(),
3849                            (bytes, handles),
3850                        )?;
3851                        Ok(OpenTargetRequest::_UnknownMethod {
3852                            ordinal: header.ordinal,
3853                            control_handle: OpenTargetControlHandle { inner: this.inner.clone() },
3854                            method_type: fidl::MethodType::TwoWay,
3855                        })
3856                    }
3857                    _ => Err(fidl::Error::UnknownOrdinal {
3858                        ordinal: header.ordinal,
3859                        protocol_name:
3860                            <OpenTargetMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME,
3861                    }),
3862                }))
3863            },
3864        )
3865    }
3866}
3867
3868#[derive(Debug)]
3869pub enum OpenTargetRequest {
3870    StrictOneWay {
3871        control_handle: OpenTargetControlHandle,
3872    },
3873    FlexibleOneWay {
3874        control_handle: OpenTargetControlHandle,
3875    },
3876    StrictTwoWay {
3877        responder: OpenTargetStrictTwoWayResponder,
3878    },
3879    StrictTwoWayFields {
3880        responder: OpenTargetStrictTwoWayFieldsResponder,
3881    },
3882    StrictTwoWayErr {
3883        responder: OpenTargetStrictTwoWayErrResponder,
3884    },
3885    StrictTwoWayFieldsErr {
3886        responder: OpenTargetStrictTwoWayFieldsErrResponder,
3887    },
3888    FlexibleTwoWay {
3889        responder: OpenTargetFlexibleTwoWayResponder,
3890    },
3891    FlexibleTwoWayFields {
3892        responder: OpenTargetFlexibleTwoWayFieldsResponder,
3893    },
3894    FlexibleTwoWayErr {
3895        responder: OpenTargetFlexibleTwoWayErrResponder,
3896    },
3897    FlexibleTwoWayFieldsErr {
3898        responder: OpenTargetFlexibleTwoWayFieldsErrResponder,
3899    },
3900    /// An interaction was received which does not match any known method.
3901    #[non_exhaustive]
3902    _UnknownMethod {
3903        /// Ordinal of the method that was called.
3904        ordinal: u64,
3905        control_handle: OpenTargetControlHandle,
3906        method_type: fidl::MethodType,
3907    },
3908}
3909
3910impl OpenTargetRequest {
3911    #[allow(irrefutable_let_patterns)]
3912    pub fn into_strict_one_way(self) -> Option<(OpenTargetControlHandle)> {
3913        if let OpenTargetRequest::StrictOneWay { control_handle } = self {
3914            Some((control_handle))
3915        } else {
3916            None
3917        }
3918    }
3919
3920    #[allow(irrefutable_let_patterns)]
3921    pub fn into_flexible_one_way(self) -> Option<(OpenTargetControlHandle)> {
3922        if let OpenTargetRequest::FlexibleOneWay { control_handle } = self {
3923            Some((control_handle))
3924        } else {
3925            None
3926        }
3927    }
3928
3929    #[allow(irrefutable_let_patterns)]
3930    pub fn into_strict_two_way(self) -> Option<(OpenTargetStrictTwoWayResponder)> {
3931        if let OpenTargetRequest::StrictTwoWay { responder } = self {
3932            Some((responder))
3933        } else {
3934            None
3935        }
3936    }
3937
3938    #[allow(irrefutable_let_patterns)]
3939    pub fn into_strict_two_way_fields(self) -> Option<(OpenTargetStrictTwoWayFieldsResponder)> {
3940        if let OpenTargetRequest::StrictTwoWayFields { responder } = self {
3941            Some((responder))
3942        } else {
3943            None
3944        }
3945    }
3946
3947    #[allow(irrefutable_let_patterns)]
3948    pub fn into_strict_two_way_err(self) -> Option<(OpenTargetStrictTwoWayErrResponder)> {
3949        if let OpenTargetRequest::StrictTwoWayErr { responder } = self {
3950            Some((responder))
3951        } else {
3952            None
3953        }
3954    }
3955
3956    #[allow(irrefutable_let_patterns)]
3957    pub fn into_strict_two_way_fields_err(
3958        self,
3959    ) -> Option<(OpenTargetStrictTwoWayFieldsErrResponder)> {
3960        if let OpenTargetRequest::StrictTwoWayFieldsErr { responder } = self {
3961            Some((responder))
3962        } else {
3963            None
3964        }
3965    }
3966
3967    #[allow(irrefutable_let_patterns)]
3968    pub fn into_flexible_two_way(self) -> Option<(OpenTargetFlexibleTwoWayResponder)> {
3969        if let OpenTargetRequest::FlexibleTwoWay { responder } = self {
3970            Some((responder))
3971        } else {
3972            None
3973        }
3974    }
3975
3976    #[allow(irrefutable_let_patterns)]
3977    pub fn into_flexible_two_way_fields(self) -> Option<(OpenTargetFlexibleTwoWayFieldsResponder)> {
3978        if let OpenTargetRequest::FlexibleTwoWayFields { responder } = self {
3979            Some((responder))
3980        } else {
3981            None
3982        }
3983    }
3984
3985    #[allow(irrefutable_let_patterns)]
3986    pub fn into_flexible_two_way_err(self) -> Option<(OpenTargetFlexibleTwoWayErrResponder)> {
3987        if let OpenTargetRequest::FlexibleTwoWayErr { responder } = self {
3988            Some((responder))
3989        } else {
3990            None
3991        }
3992    }
3993
3994    #[allow(irrefutable_let_patterns)]
3995    pub fn into_flexible_two_way_fields_err(
3996        self,
3997    ) -> Option<(OpenTargetFlexibleTwoWayFieldsErrResponder)> {
3998        if let OpenTargetRequest::FlexibleTwoWayFieldsErr { responder } = self {
3999            Some((responder))
4000        } else {
4001            None
4002        }
4003    }
4004
4005    /// Name of the method defined in FIDL
4006    pub fn method_name(&self) -> &'static str {
4007        match *self {
4008            OpenTargetRequest::StrictOneWay { .. } => "strict_one_way",
4009            OpenTargetRequest::FlexibleOneWay { .. } => "flexible_one_way",
4010            OpenTargetRequest::StrictTwoWay { .. } => "strict_two_way",
4011            OpenTargetRequest::StrictTwoWayFields { .. } => "strict_two_way_fields",
4012            OpenTargetRequest::StrictTwoWayErr { .. } => "strict_two_way_err",
4013            OpenTargetRequest::StrictTwoWayFieldsErr { .. } => "strict_two_way_fields_err",
4014            OpenTargetRequest::FlexibleTwoWay { .. } => "flexible_two_way",
4015            OpenTargetRequest::FlexibleTwoWayFields { .. } => "flexible_two_way_fields",
4016            OpenTargetRequest::FlexibleTwoWayErr { .. } => "flexible_two_way_err",
4017            OpenTargetRequest::FlexibleTwoWayFieldsErr { .. } => "flexible_two_way_fields_err",
4018            OpenTargetRequest::_UnknownMethod { method_type: fidl::MethodType::OneWay, .. } => {
4019                "unknown one-way method"
4020            }
4021            OpenTargetRequest::_UnknownMethod { method_type: fidl::MethodType::TwoWay, .. } => {
4022                "unknown two-way method"
4023            }
4024        }
4025    }
4026}
4027
4028#[derive(Debug, Clone)]
4029pub struct OpenTargetControlHandle {
4030    inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
4031}
4032
4033impl fidl::endpoints::ControlHandle for OpenTargetControlHandle {
4034    fn shutdown(&self) {
4035        self.inner.shutdown()
4036    }
4037    fn shutdown_with_epitaph(&self, status: zx_status::Status) {
4038        self.inner.shutdown_with_epitaph(status)
4039    }
4040
4041    fn is_closed(&self) -> bool {
4042        self.inner.channel().is_closed()
4043    }
4044    fn on_closed(&self) -> fidl::OnSignalsRef<'_> {
4045        self.inner.channel().on_closed()
4046    }
4047
4048    #[cfg(target_os = "fuchsia")]
4049    fn signal_peer(
4050        &self,
4051        clear_mask: zx::Signals,
4052        set_mask: zx::Signals,
4053    ) -> Result<(), zx_status::Status> {
4054        use fidl::Peered;
4055        self.inner.channel().signal_peer(clear_mask, set_mask)
4056    }
4057}
4058
4059impl OpenTargetControlHandle {
4060    pub fn send_strict_event(&self) -> Result<(), fidl::Error> {
4061        self.inner.send::<fidl::encoding::EmptyPayload>(
4062            (),
4063            0,
4064            0x2b291d74321e77a0,
4065            fidl::encoding::DynamicFlags::empty(),
4066        )
4067    }
4068
4069    pub fn send_flexible_event(&self) -> Result<(), fidl::Error> {
4070        self.inner.send::<fidl::encoding::EmptyPayload>(
4071            (),
4072            0,
4073            0x50d4688058898898,
4074            fidl::encoding::DynamicFlags::FLEXIBLE,
4075        )
4076    }
4077}
4078
4079#[must_use = "FIDL methods require a response to be sent"]
4080#[derive(Debug)]
4081pub struct OpenTargetStrictTwoWayResponder {
4082    control_handle: std::mem::ManuallyDrop<OpenTargetControlHandle>,
4083    tx_id: u32,
4084}
4085
4086/// Set the the channel to be shutdown (see [`OpenTargetControlHandle::shutdown`])
4087/// if the responder is dropped without sending a response, so that the client
4088/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
4089impl std::ops::Drop for OpenTargetStrictTwoWayResponder {
4090    fn drop(&mut self) {
4091        self.control_handle.shutdown();
4092        // Safety: drops once, never accessed again
4093        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
4094    }
4095}
4096
4097impl fidl::endpoints::Responder for OpenTargetStrictTwoWayResponder {
4098    type ControlHandle = OpenTargetControlHandle;
4099
4100    fn control_handle(&self) -> &OpenTargetControlHandle {
4101        &self.control_handle
4102    }
4103
4104    fn drop_without_shutdown(mut self) {
4105        // Safety: drops once, never accessed again due to mem::forget
4106        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
4107        // Prevent Drop from running (which would shut down the channel)
4108        std::mem::forget(self);
4109    }
4110}
4111
4112impl OpenTargetStrictTwoWayResponder {
4113    /// Sends a response to the FIDL transaction.
4114    ///
4115    /// Sets the channel to shutdown if an error occurs.
4116    pub fn send(self) -> Result<(), fidl::Error> {
4117        let _result = self.send_raw();
4118        if _result.is_err() {
4119            self.control_handle.shutdown();
4120        }
4121        self.drop_without_shutdown();
4122        _result
4123    }
4124
4125    /// Similar to "send" but does not shutdown the channel if an error occurs.
4126    pub fn send_no_shutdown_on_err(self) -> Result<(), fidl::Error> {
4127        let _result = self.send_raw();
4128        self.drop_without_shutdown();
4129        _result
4130    }
4131
4132    fn send_raw(&self) -> Result<(), fidl::Error> {
4133        self.control_handle.inner.send::<fidl::encoding::EmptyPayload>(
4134            (),
4135            self.tx_id,
4136            0xdcf4cef19a1c542,
4137            fidl::encoding::DynamicFlags::empty(),
4138        )
4139    }
4140}
4141
4142#[must_use = "FIDL methods require a response to be sent"]
4143#[derive(Debug)]
4144pub struct OpenTargetStrictTwoWayFieldsResponder {
4145    control_handle: std::mem::ManuallyDrop<OpenTargetControlHandle>,
4146    tx_id: u32,
4147}
4148
4149/// Set the the channel to be shutdown (see [`OpenTargetControlHandle::shutdown`])
4150/// if the responder is dropped without sending a response, so that the client
4151/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
4152impl std::ops::Drop for OpenTargetStrictTwoWayFieldsResponder {
4153    fn drop(&mut self) {
4154        self.control_handle.shutdown();
4155        // Safety: drops once, never accessed again
4156        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
4157    }
4158}
4159
4160impl fidl::endpoints::Responder for OpenTargetStrictTwoWayFieldsResponder {
4161    type ControlHandle = OpenTargetControlHandle;
4162
4163    fn control_handle(&self) -> &OpenTargetControlHandle {
4164        &self.control_handle
4165    }
4166
4167    fn drop_without_shutdown(mut self) {
4168        // Safety: drops once, never accessed again due to mem::forget
4169        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
4170        // Prevent Drop from running (which would shut down the channel)
4171        std::mem::forget(self);
4172    }
4173}
4174
4175impl OpenTargetStrictTwoWayFieldsResponder {
4176    /// Sends a response to the FIDL transaction.
4177    ///
4178    /// Sets the channel to shutdown if an error occurs.
4179    pub fn send(self, mut some_field: i32) -> Result<(), fidl::Error> {
4180        let _result = self.send_raw(some_field);
4181        if _result.is_err() {
4182            self.control_handle.shutdown();
4183        }
4184        self.drop_without_shutdown();
4185        _result
4186    }
4187
4188    /// Similar to "send" but does not shutdown the channel if an error occurs.
4189    pub fn send_no_shutdown_on_err(self, mut some_field: i32) -> Result<(), fidl::Error> {
4190        let _result = self.send_raw(some_field);
4191        self.drop_without_shutdown();
4192        _result
4193    }
4194
4195    fn send_raw(&self, mut some_field: i32) -> Result<(), fidl::Error> {
4196        self.control_handle.inner.send::<NonEmptyPayload>(
4197            (some_field,),
4198            self.tx_id,
4199            0x79c7a7803c45e2e3,
4200            fidl::encoding::DynamicFlags::empty(),
4201        )
4202    }
4203}
4204
4205#[must_use = "FIDL methods require a response to be sent"]
4206#[derive(Debug)]
4207pub struct OpenTargetStrictTwoWayErrResponder {
4208    control_handle: std::mem::ManuallyDrop<OpenTargetControlHandle>,
4209    tx_id: u32,
4210}
4211
4212/// Set the the channel to be shutdown (see [`OpenTargetControlHandle::shutdown`])
4213/// if the responder is dropped without sending a response, so that the client
4214/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
4215impl std::ops::Drop for OpenTargetStrictTwoWayErrResponder {
4216    fn drop(&mut self) {
4217        self.control_handle.shutdown();
4218        // Safety: drops once, never accessed again
4219        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
4220    }
4221}
4222
4223impl fidl::endpoints::Responder for OpenTargetStrictTwoWayErrResponder {
4224    type ControlHandle = OpenTargetControlHandle;
4225
4226    fn control_handle(&self) -> &OpenTargetControlHandle {
4227        &self.control_handle
4228    }
4229
4230    fn drop_without_shutdown(mut self) {
4231        // Safety: drops once, never accessed again due to mem::forget
4232        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
4233        // Prevent Drop from running (which would shut down the channel)
4234        std::mem::forget(self);
4235    }
4236}
4237
4238impl OpenTargetStrictTwoWayErrResponder {
4239    /// Sends a response to the FIDL transaction.
4240    ///
4241    /// Sets the channel to shutdown if an error occurs.
4242    pub fn send(self, mut result: Result<(), i32>) -> Result<(), fidl::Error> {
4243        let _result = self.send_raw(result);
4244        if _result.is_err() {
4245            self.control_handle.shutdown();
4246        }
4247        self.drop_without_shutdown();
4248        _result
4249    }
4250
4251    /// Similar to "send" but does not shutdown the channel if an error occurs.
4252    pub fn send_no_shutdown_on_err(self, mut result: Result<(), i32>) -> Result<(), fidl::Error> {
4253        let _result = self.send_raw(result);
4254        self.drop_without_shutdown();
4255        _result
4256    }
4257
4258    fn send_raw(&self, mut result: Result<(), i32>) -> Result<(), fidl::Error> {
4259        self.control_handle
4260            .inner
4261            .send::<fidl::encoding::ResultType<fidl::encoding::EmptyStruct, i32>>(
4262                result,
4263                self.tx_id,
4264                0x54259ed6c262fe88,
4265                fidl::encoding::DynamicFlags::empty(),
4266            )
4267    }
4268}
4269
4270#[must_use = "FIDL methods require a response to be sent"]
4271#[derive(Debug)]
4272pub struct OpenTargetStrictTwoWayFieldsErrResponder {
4273    control_handle: std::mem::ManuallyDrop<OpenTargetControlHandle>,
4274    tx_id: u32,
4275}
4276
4277/// Set the the channel to be shutdown (see [`OpenTargetControlHandle::shutdown`])
4278/// if the responder is dropped without sending a response, so that the client
4279/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
4280impl std::ops::Drop for OpenTargetStrictTwoWayFieldsErrResponder {
4281    fn drop(&mut self) {
4282        self.control_handle.shutdown();
4283        // Safety: drops once, never accessed again
4284        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
4285    }
4286}
4287
4288impl fidl::endpoints::Responder for OpenTargetStrictTwoWayFieldsErrResponder {
4289    type ControlHandle = OpenTargetControlHandle;
4290
4291    fn control_handle(&self) -> &OpenTargetControlHandle {
4292        &self.control_handle
4293    }
4294
4295    fn drop_without_shutdown(mut self) {
4296        // Safety: drops once, never accessed again due to mem::forget
4297        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
4298        // Prevent Drop from running (which would shut down the channel)
4299        std::mem::forget(self);
4300    }
4301}
4302
4303impl OpenTargetStrictTwoWayFieldsErrResponder {
4304    /// Sends a response to the FIDL transaction.
4305    ///
4306    /// Sets the channel to shutdown if an error occurs.
4307    pub fn send(self, mut result: Result<i32, i32>) -> Result<(), fidl::Error> {
4308        let _result = self.send_raw(result);
4309        if _result.is_err() {
4310            self.control_handle.shutdown();
4311        }
4312        self.drop_without_shutdown();
4313        _result
4314    }
4315
4316    /// Similar to "send" but does not shutdown the channel if an error occurs.
4317    pub fn send_no_shutdown_on_err(self, mut result: Result<i32, i32>) -> Result<(), fidl::Error> {
4318        let _result = self.send_raw(result);
4319        self.drop_without_shutdown();
4320        _result
4321    }
4322
4323    fn send_raw(&self, mut result: Result<i32, i32>) -> Result<(), fidl::Error> {
4324        self.control_handle.inner.send::<fidl::encoding::ResultType<NonEmptyPayload, i32>>(
4325            result.map(|some_field| (some_field,)),
4326            self.tx_id,
4327            0x7dbaa8538b552711,
4328            fidl::encoding::DynamicFlags::empty(),
4329        )
4330    }
4331}
4332
4333#[must_use = "FIDL methods require a response to be sent"]
4334#[derive(Debug)]
4335pub struct OpenTargetFlexibleTwoWayResponder {
4336    control_handle: std::mem::ManuallyDrop<OpenTargetControlHandle>,
4337    tx_id: u32,
4338}
4339
4340/// Set the the channel to be shutdown (see [`OpenTargetControlHandle::shutdown`])
4341/// if the responder is dropped without sending a response, so that the client
4342/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
4343impl std::ops::Drop for OpenTargetFlexibleTwoWayResponder {
4344    fn drop(&mut self) {
4345        self.control_handle.shutdown();
4346        // Safety: drops once, never accessed again
4347        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
4348    }
4349}
4350
4351impl fidl::endpoints::Responder for OpenTargetFlexibleTwoWayResponder {
4352    type ControlHandle = OpenTargetControlHandle;
4353
4354    fn control_handle(&self) -> &OpenTargetControlHandle {
4355        &self.control_handle
4356    }
4357
4358    fn drop_without_shutdown(mut self) {
4359        // Safety: drops once, never accessed again due to mem::forget
4360        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
4361        // Prevent Drop from running (which would shut down the channel)
4362        std::mem::forget(self);
4363    }
4364}
4365
4366impl OpenTargetFlexibleTwoWayResponder {
4367    /// Sends a response to the FIDL transaction.
4368    ///
4369    /// Sets the channel to shutdown if an error occurs.
4370    pub fn send(self) -> Result<(), fidl::Error> {
4371        let _result = self.send_raw();
4372        if _result.is_err() {
4373            self.control_handle.shutdown();
4374        }
4375        self.drop_without_shutdown();
4376        _result
4377    }
4378
4379    /// Similar to "send" but does not shutdown the channel if an error occurs.
4380    pub fn send_no_shutdown_on_err(self) -> Result<(), fidl::Error> {
4381        let _result = self.send_raw();
4382        self.drop_without_shutdown();
4383        _result
4384    }
4385
4386    fn send_raw(&self) -> Result<(), fidl::Error> {
4387        self.control_handle.inner.send::<fidl::encoding::FlexibleType<fidl::encoding::EmptyStruct>>(
4388            fidl::encoding::Flexible::new(()),
4389            self.tx_id,
4390            0x66552e68b99a0587,
4391            fidl::encoding::DynamicFlags::FLEXIBLE,
4392        )
4393    }
4394}
4395
4396#[must_use = "FIDL methods require a response to be sent"]
4397#[derive(Debug)]
4398pub struct OpenTargetFlexibleTwoWayFieldsResponder {
4399    control_handle: std::mem::ManuallyDrop<OpenTargetControlHandle>,
4400    tx_id: u32,
4401}
4402
4403/// Set the the channel to be shutdown (see [`OpenTargetControlHandle::shutdown`])
4404/// if the responder is dropped without sending a response, so that the client
4405/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
4406impl std::ops::Drop for OpenTargetFlexibleTwoWayFieldsResponder {
4407    fn drop(&mut self) {
4408        self.control_handle.shutdown();
4409        // Safety: drops once, never accessed again
4410        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
4411    }
4412}
4413
4414impl fidl::endpoints::Responder for OpenTargetFlexibleTwoWayFieldsResponder {
4415    type ControlHandle = OpenTargetControlHandle;
4416
4417    fn control_handle(&self) -> &OpenTargetControlHandle {
4418        &self.control_handle
4419    }
4420
4421    fn drop_without_shutdown(mut self) {
4422        // Safety: drops once, never accessed again due to mem::forget
4423        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
4424        // Prevent Drop from running (which would shut down the channel)
4425        std::mem::forget(self);
4426    }
4427}
4428
4429impl OpenTargetFlexibleTwoWayFieldsResponder {
4430    /// Sends a response to the FIDL transaction.
4431    ///
4432    /// Sets the channel to shutdown if an error occurs.
4433    pub fn send(self, mut some_field: i32) -> Result<(), fidl::Error> {
4434        let _result = self.send_raw(some_field);
4435        if _result.is_err() {
4436            self.control_handle.shutdown();
4437        }
4438        self.drop_without_shutdown();
4439        _result
4440    }
4441
4442    /// Similar to "send" but does not shutdown the channel if an error occurs.
4443    pub fn send_no_shutdown_on_err(self, mut some_field: i32) -> Result<(), fidl::Error> {
4444        let _result = self.send_raw(some_field);
4445        self.drop_without_shutdown();
4446        _result
4447    }
4448
4449    fn send_raw(&self, mut some_field: i32) -> Result<(), fidl::Error> {
4450        self.control_handle.inner.send::<fidl::encoding::FlexibleType<NonEmptyPayload>>(
4451            fidl::encoding::Flexible::new((some_field,)),
4452            self.tx_id,
4453            0x38b95648ac4e2ae4,
4454            fidl::encoding::DynamicFlags::FLEXIBLE,
4455        )
4456    }
4457}
4458
4459#[must_use = "FIDL methods require a response to be sent"]
4460#[derive(Debug)]
4461pub struct OpenTargetFlexibleTwoWayErrResponder {
4462    control_handle: std::mem::ManuallyDrop<OpenTargetControlHandle>,
4463    tx_id: u32,
4464}
4465
4466/// Set the the channel to be shutdown (see [`OpenTargetControlHandle::shutdown`])
4467/// if the responder is dropped without sending a response, so that the client
4468/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
4469impl std::ops::Drop for OpenTargetFlexibleTwoWayErrResponder {
4470    fn drop(&mut self) {
4471        self.control_handle.shutdown();
4472        // Safety: drops once, never accessed again
4473        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
4474    }
4475}
4476
4477impl fidl::endpoints::Responder for OpenTargetFlexibleTwoWayErrResponder {
4478    type ControlHandle = OpenTargetControlHandle;
4479
4480    fn control_handle(&self) -> &OpenTargetControlHandle {
4481        &self.control_handle
4482    }
4483
4484    fn drop_without_shutdown(mut self) {
4485        // Safety: drops once, never accessed again due to mem::forget
4486        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
4487        // Prevent Drop from running (which would shut down the channel)
4488        std::mem::forget(self);
4489    }
4490}
4491
4492impl OpenTargetFlexibleTwoWayErrResponder {
4493    /// Sends a response to the FIDL transaction.
4494    ///
4495    /// Sets the channel to shutdown if an error occurs.
4496    pub fn send(self, mut result: Result<(), i32>) -> Result<(), fidl::Error> {
4497        let _result = self.send_raw(result);
4498        if _result.is_err() {
4499            self.control_handle.shutdown();
4500        }
4501        self.drop_without_shutdown();
4502        _result
4503    }
4504
4505    /// Similar to "send" but does not shutdown the channel if an error occurs.
4506    pub fn send_no_shutdown_on_err(self, mut result: Result<(), i32>) -> Result<(), fidl::Error> {
4507        let _result = self.send_raw(result);
4508        self.drop_without_shutdown();
4509        _result
4510    }
4511
4512    fn send_raw(&self, mut result: Result<(), i32>) -> Result<(), fidl::Error> {
4513        self.control_handle.inner.send::<fidl::encoding::FlexibleResultType<
4514            fidl::encoding::EmptyStruct,
4515            i32,
4516        >>(
4517            fidl::encoding::FlexibleResult::new(result),
4518            self.tx_id,
4519            0x6e144c6e0cf2147a,
4520            fidl::encoding::DynamicFlags::FLEXIBLE,
4521        )
4522    }
4523}
4524
4525#[must_use = "FIDL methods require a response to be sent"]
4526#[derive(Debug)]
4527pub struct OpenTargetFlexibleTwoWayFieldsErrResponder {
4528    control_handle: std::mem::ManuallyDrop<OpenTargetControlHandle>,
4529    tx_id: u32,
4530}
4531
4532/// Set the the channel to be shutdown (see [`OpenTargetControlHandle::shutdown`])
4533/// if the responder is dropped without sending a response, so that the client
4534/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
4535impl std::ops::Drop for OpenTargetFlexibleTwoWayFieldsErrResponder {
4536    fn drop(&mut self) {
4537        self.control_handle.shutdown();
4538        // Safety: drops once, never accessed again
4539        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
4540    }
4541}
4542
4543impl fidl::endpoints::Responder for OpenTargetFlexibleTwoWayFieldsErrResponder {
4544    type ControlHandle = OpenTargetControlHandle;
4545
4546    fn control_handle(&self) -> &OpenTargetControlHandle {
4547        &self.control_handle
4548    }
4549
4550    fn drop_without_shutdown(mut self) {
4551        // Safety: drops once, never accessed again due to mem::forget
4552        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
4553        // Prevent Drop from running (which would shut down the channel)
4554        std::mem::forget(self);
4555    }
4556}
4557
4558impl OpenTargetFlexibleTwoWayFieldsErrResponder {
4559    /// Sends a response to the FIDL transaction.
4560    ///
4561    /// Sets the channel to shutdown if an error occurs.
4562    pub fn send(self, mut result: Result<i32, i32>) -> Result<(), fidl::Error> {
4563        let _result = self.send_raw(result);
4564        if _result.is_err() {
4565            self.control_handle.shutdown();
4566        }
4567        self.drop_without_shutdown();
4568        _result
4569    }
4570
4571    /// Similar to "send" but does not shutdown the channel if an error occurs.
4572    pub fn send_no_shutdown_on_err(self, mut result: Result<i32, i32>) -> Result<(), fidl::Error> {
4573        let _result = self.send_raw(result);
4574        self.drop_without_shutdown();
4575        _result
4576    }
4577
4578    fn send_raw(&self, mut result: Result<i32, i32>) -> Result<(), fidl::Error> {
4579        self.control_handle.inner.send::<fidl::encoding::FlexibleResultType<NonEmptyPayload, i32>>(
4580            fidl::encoding::FlexibleResult::new(result.map(|some_field| (some_field,))),
4581            self.tx_id,
4582            0xe494147cda8024a,
4583            fidl::encoding::DynamicFlags::FLEXIBLE,
4584        )
4585    }
4586}
4587
4588#[derive(Debug, Copy, Clone, Eq, PartialEq, Ord, PartialOrd, Hash)]
4589pub struct OpenTargetEventReporterMarker;
4590
4591impl fidl::endpoints::ProtocolMarker for OpenTargetEventReporterMarker {
4592    type Proxy = OpenTargetEventReporterProxy;
4593    type RequestStream = OpenTargetEventReporterRequestStream;
4594    #[cfg(target_os = "fuchsia")]
4595    type SynchronousProxy = OpenTargetEventReporterSynchronousProxy;
4596
4597    const DEBUG_NAME: &'static str = "(anonymous) OpenTargetEventReporter";
4598}
4599
4600pub trait OpenTargetEventReporterProxyInterface: Send + Sync {
4601    fn r#report_event(&self, payload: &OpenTargetEventReport) -> Result<(), fidl::Error>;
4602}
4603#[derive(Debug)]
4604#[cfg(target_os = "fuchsia")]
4605pub struct OpenTargetEventReporterSynchronousProxy {
4606    client: fidl::client::sync::Client,
4607}
4608
4609#[cfg(target_os = "fuchsia")]
4610impl fidl::endpoints::SynchronousProxy for OpenTargetEventReporterSynchronousProxy {
4611    type Proxy = OpenTargetEventReporterProxy;
4612    type Protocol = OpenTargetEventReporterMarker;
4613
4614    fn from_channel(inner: fidl::Channel) -> Self {
4615        Self::new(inner)
4616    }
4617
4618    fn into_channel(self) -> fidl::Channel {
4619        self.client.into_channel()
4620    }
4621
4622    fn as_channel(&self) -> &fidl::Channel {
4623        self.client.as_channel()
4624    }
4625}
4626
4627#[cfg(target_os = "fuchsia")]
4628impl OpenTargetEventReporterSynchronousProxy {
4629    pub fn new(channel: fidl::Channel) -> Self {
4630        let protocol_name =
4631            <OpenTargetEventReporterMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME;
4632        Self { client: fidl::client::sync::Client::new(channel, protocol_name) }
4633    }
4634
4635    pub fn into_channel(self) -> fidl::Channel {
4636        self.client.into_channel()
4637    }
4638
4639    /// Waits until an event arrives and returns it. It is safe for other
4640    /// threads to make concurrent requests while waiting for an event.
4641    pub fn wait_for_event(
4642        &self,
4643        deadline: zx::MonotonicInstant,
4644    ) -> Result<OpenTargetEventReporterEvent, fidl::Error> {
4645        OpenTargetEventReporterEvent::decode(self.client.wait_for_event(deadline)?)
4646    }
4647
4648    pub fn r#report_event(&self, mut payload: &OpenTargetEventReport) -> Result<(), fidl::Error> {
4649        self.client.send::<OpenTargetEventReport>(
4650            payload,
4651            0x70ab38ec0248964a,
4652            fidl::encoding::DynamicFlags::empty(),
4653        )
4654    }
4655}
4656
4657#[cfg(target_os = "fuchsia")]
4658impl From<OpenTargetEventReporterSynchronousProxy> for zx::Handle {
4659    fn from(value: OpenTargetEventReporterSynchronousProxy) -> Self {
4660        value.into_channel().into()
4661    }
4662}
4663
4664#[cfg(target_os = "fuchsia")]
4665impl From<fidl::Channel> for OpenTargetEventReporterSynchronousProxy {
4666    fn from(value: fidl::Channel) -> Self {
4667        Self::new(value)
4668    }
4669}
4670
4671#[derive(Debug, Clone)]
4672pub struct OpenTargetEventReporterProxy {
4673    client: fidl::client::Client<fidl::encoding::DefaultFuchsiaResourceDialect>,
4674}
4675
4676impl fidl::endpoints::Proxy for OpenTargetEventReporterProxy {
4677    type Protocol = OpenTargetEventReporterMarker;
4678
4679    fn from_channel(inner: ::fidl::AsyncChannel) -> Self {
4680        Self::new(inner)
4681    }
4682
4683    fn into_channel(self) -> Result<::fidl::AsyncChannel, Self> {
4684        self.client.into_channel().map_err(|client| Self { client })
4685    }
4686
4687    fn as_channel(&self) -> &::fidl::AsyncChannel {
4688        self.client.as_channel()
4689    }
4690}
4691
4692impl OpenTargetEventReporterProxy {
4693    /// Create a new Proxy for fidl.clientsuite/OpenTargetEventReporter.
4694    pub fn new(channel: ::fidl::AsyncChannel) -> Self {
4695        let protocol_name =
4696            <OpenTargetEventReporterMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME;
4697        Self { client: fidl::client::Client::new(channel, protocol_name) }
4698    }
4699
4700    /// Get a Stream of events from the remote end of the protocol.
4701    ///
4702    /// # Panics
4703    ///
4704    /// Panics if the event stream was already taken.
4705    pub fn take_event_stream(&self) -> OpenTargetEventReporterEventStream {
4706        OpenTargetEventReporterEventStream { event_receiver: self.client.take_event_receiver() }
4707    }
4708
4709    pub fn r#report_event(&self, mut payload: &OpenTargetEventReport) -> Result<(), fidl::Error> {
4710        OpenTargetEventReporterProxyInterface::r#report_event(self, payload)
4711    }
4712}
4713
4714impl OpenTargetEventReporterProxyInterface for OpenTargetEventReporterProxy {
4715    fn r#report_event(&self, mut payload: &OpenTargetEventReport) -> Result<(), fidl::Error> {
4716        self.client.send::<OpenTargetEventReport>(
4717            payload,
4718            0x70ab38ec0248964a,
4719            fidl::encoding::DynamicFlags::empty(),
4720        )
4721    }
4722}
4723
4724pub struct OpenTargetEventReporterEventStream {
4725    event_receiver: fidl::client::EventReceiver<fidl::encoding::DefaultFuchsiaResourceDialect>,
4726}
4727
4728impl std::marker::Unpin for OpenTargetEventReporterEventStream {}
4729
4730impl futures::stream::FusedStream for OpenTargetEventReporterEventStream {
4731    fn is_terminated(&self) -> bool {
4732        self.event_receiver.is_terminated()
4733    }
4734}
4735
4736impl futures::Stream for OpenTargetEventReporterEventStream {
4737    type Item = Result<OpenTargetEventReporterEvent, fidl::Error>;
4738
4739    fn poll_next(
4740        mut self: std::pin::Pin<&mut Self>,
4741        cx: &mut std::task::Context<'_>,
4742    ) -> std::task::Poll<Option<Self::Item>> {
4743        match futures::ready!(futures::stream::StreamExt::poll_next_unpin(
4744            &mut self.event_receiver,
4745            cx
4746        )?) {
4747            Some(buf) => std::task::Poll::Ready(Some(OpenTargetEventReporterEvent::decode(buf))),
4748            None => std::task::Poll::Ready(None),
4749        }
4750    }
4751}
4752
4753#[derive(Debug)]
4754pub enum OpenTargetEventReporterEvent {}
4755
4756impl OpenTargetEventReporterEvent {
4757    /// Decodes a message buffer as a [`OpenTargetEventReporterEvent`].
4758    fn decode(
4759        mut buf: <fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc,
4760    ) -> Result<OpenTargetEventReporterEvent, fidl::Error> {
4761        let (bytes, _handles) = buf.split_mut();
4762        let (tx_header, _body_bytes) = fidl::encoding::decode_transaction_header(bytes)?;
4763        debug_assert_eq!(tx_header.tx_id, 0);
4764        match tx_header.ordinal {
4765            _ => Err(fidl::Error::UnknownOrdinal {
4766                ordinal: tx_header.ordinal,
4767                protocol_name:
4768                    <OpenTargetEventReporterMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME,
4769            }),
4770        }
4771    }
4772}
4773
4774/// A Stream of incoming requests for fidl.clientsuite/OpenTargetEventReporter.
4775pub struct OpenTargetEventReporterRequestStream {
4776    inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
4777    is_terminated: bool,
4778}
4779
4780impl std::marker::Unpin for OpenTargetEventReporterRequestStream {}
4781
4782impl futures::stream::FusedStream for OpenTargetEventReporterRequestStream {
4783    fn is_terminated(&self) -> bool {
4784        self.is_terminated
4785    }
4786}
4787
4788impl fidl::endpoints::RequestStream for OpenTargetEventReporterRequestStream {
4789    type Protocol = OpenTargetEventReporterMarker;
4790    type ControlHandle = OpenTargetEventReporterControlHandle;
4791
4792    fn from_channel(channel: ::fidl::AsyncChannel) -> Self {
4793        Self { inner: std::sync::Arc::new(fidl::ServeInner::new(channel)), is_terminated: false }
4794    }
4795
4796    fn control_handle(&self) -> Self::ControlHandle {
4797        OpenTargetEventReporterControlHandle { inner: self.inner.clone() }
4798    }
4799
4800    fn into_inner(
4801        self,
4802    ) -> (::std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>, bool)
4803    {
4804        (self.inner, self.is_terminated)
4805    }
4806
4807    fn from_inner(
4808        inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
4809        is_terminated: bool,
4810    ) -> Self {
4811        Self { inner, is_terminated }
4812    }
4813}
4814
4815impl futures::Stream for OpenTargetEventReporterRequestStream {
4816    type Item = Result<OpenTargetEventReporterRequest, fidl::Error>;
4817
4818    fn poll_next(
4819        mut self: std::pin::Pin<&mut Self>,
4820        cx: &mut std::task::Context<'_>,
4821    ) -> std::task::Poll<Option<Self::Item>> {
4822        let this = &mut *self;
4823        if this.inner.check_shutdown(cx) {
4824            this.is_terminated = true;
4825            return std::task::Poll::Ready(None);
4826        }
4827        if this.is_terminated {
4828            panic!("polled OpenTargetEventReporterRequestStream after completion");
4829        }
4830        fidl::encoding::with_tls_decode_buf::<_, fidl::encoding::DefaultFuchsiaResourceDialect>(
4831            |bytes, handles| {
4832                match this.inner.channel().read_etc(cx, bytes, handles) {
4833                    std::task::Poll::Ready(Ok(())) => {}
4834                    std::task::Poll::Pending => return std::task::Poll::Pending,
4835                    std::task::Poll::Ready(Err(zx_status::Status::PEER_CLOSED)) => {
4836                        this.is_terminated = true;
4837                        return std::task::Poll::Ready(None);
4838                    }
4839                    std::task::Poll::Ready(Err(e)) => {
4840                        return std::task::Poll::Ready(Some(Err(fidl::Error::ServerRequestRead(
4841                            e.into(),
4842                        ))))
4843                    }
4844                }
4845
4846                // A message has been received from the channel
4847                let (header, _body_bytes) = fidl::encoding::decode_transaction_header(bytes)?;
4848
4849                std::task::Poll::Ready(Some(match header.ordinal {
4850                0x70ab38ec0248964a => {
4851                    header.validate_request_tx_id(fidl::MethodType::OneWay)?;
4852                    let mut req = fidl::new_empty!(OpenTargetEventReport, fidl::encoding::DefaultFuchsiaResourceDialect);
4853                    fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<OpenTargetEventReport>(&header, _body_bytes, handles, &mut req)?;
4854                    let control_handle = OpenTargetEventReporterControlHandle {
4855                        inner: this.inner.clone(),
4856                    };
4857                    Ok(OpenTargetEventReporterRequest::ReportEvent {payload: req,
4858                        control_handle,
4859                    })
4860                }
4861                _ => Err(fidl::Error::UnknownOrdinal {
4862                    ordinal: header.ordinal,
4863                    protocol_name: <OpenTargetEventReporterMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME,
4864                }),
4865            }))
4866            },
4867        )
4868    }
4869}
4870
4871#[derive(Debug)]
4872pub enum OpenTargetEventReporterRequest {
4873    ReportEvent {
4874        payload: OpenTargetEventReport,
4875        control_handle: OpenTargetEventReporterControlHandle,
4876    },
4877}
4878
4879impl OpenTargetEventReporterRequest {
4880    #[allow(irrefutable_let_patterns)]
4881    pub fn into_report_event(
4882        self,
4883    ) -> Option<(OpenTargetEventReport, OpenTargetEventReporterControlHandle)> {
4884        if let OpenTargetEventReporterRequest::ReportEvent { payload, control_handle } = self {
4885            Some((payload, control_handle))
4886        } else {
4887            None
4888        }
4889    }
4890
4891    /// Name of the method defined in FIDL
4892    pub fn method_name(&self) -> &'static str {
4893        match *self {
4894            OpenTargetEventReporterRequest::ReportEvent { .. } => "report_event",
4895        }
4896    }
4897}
4898
4899#[derive(Debug, Clone)]
4900pub struct OpenTargetEventReporterControlHandle {
4901    inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
4902}
4903
4904impl fidl::endpoints::ControlHandle for OpenTargetEventReporterControlHandle {
4905    fn shutdown(&self) {
4906        self.inner.shutdown()
4907    }
4908    fn shutdown_with_epitaph(&self, status: zx_status::Status) {
4909        self.inner.shutdown_with_epitaph(status)
4910    }
4911
4912    fn is_closed(&self) -> bool {
4913        self.inner.channel().is_closed()
4914    }
4915    fn on_closed(&self) -> fidl::OnSignalsRef<'_> {
4916        self.inner.channel().on_closed()
4917    }
4918
4919    #[cfg(target_os = "fuchsia")]
4920    fn signal_peer(
4921        &self,
4922        clear_mask: zx::Signals,
4923        set_mask: zx::Signals,
4924    ) -> Result<(), zx_status::Status> {
4925        use fidl::Peered;
4926        self.inner.channel().signal_peer(clear_mask, set_mask)
4927    }
4928}
4929
4930impl OpenTargetEventReporterControlHandle {}
4931
4932#[derive(Debug, Copy, Clone, Eq, PartialEq, Ord, PartialOrd, Hash)]
4933pub struct RunnerMarker;
4934
4935impl fidl::endpoints::ProtocolMarker for RunnerMarker {
4936    type Proxy = RunnerProxy;
4937    type RequestStream = RunnerRequestStream;
4938    #[cfg(target_os = "fuchsia")]
4939    type SynchronousProxy = RunnerSynchronousProxy;
4940
4941    const DEBUG_NAME: &'static str = "fidl.clientsuite.Runner";
4942}
4943impl fidl::endpoints::DiscoverableProtocolMarker for RunnerMarker {}
4944
4945pub trait RunnerProxyInterface: Send + Sync {
4946    type GetVersionResponseFut: std::future::Future<Output = Result<u64, fidl::Error>> + Send;
4947    fn r#get_version(&self) -> Self::GetVersionResponseFut;
4948    type IsTestEnabledResponseFut: std::future::Future<Output = Result<bool, fidl::Error>> + Send;
4949    fn r#is_test_enabled(&self, test: Test) -> Self::IsTestEnabledResponseFut;
4950    type CheckAliveResponseFut: std::future::Future<Output = Result<(), fidl::Error>> + Send;
4951    fn r#check_alive(&self) -> Self::CheckAliveResponseFut;
4952    type GetBindingsPropertiesResponseFut: std::future::Future<Output = Result<BindingsProperties, fidl::Error>>
4953        + Send;
4954    fn r#get_bindings_properties(&self) -> Self::GetBindingsPropertiesResponseFut;
4955    type CallTwoWayNoPayloadResponseFut: std::future::Future<Output = Result<EmptyResultClassification, fidl::Error>>
4956        + Send;
4957    fn r#call_two_way_no_payload(
4958        &self,
4959        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
4960    ) -> Self::CallTwoWayNoPayloadResponseFut;
4961    type CallTwoWayStructPayloadResponseFut: std::future::Future<Output = Result<NonEmptyResultClassification, fidl::Error>>
4962        + Send;
4963    fn r#call_two_way_struct_payload(
4964        &self,
4965        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
4966    ) -> Self::CallTwoWayStructPayloadResponseFut;
4967    type CallTwoWayTablePayloadResponseFut: std::future::Future<Output = Result<TableResultClassification, fidl::Error>>
4968        + Send;
4969    fn r#call_two_way_table_payload(
4970        &self,
4971        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
4972    ) -> Self::CallTwoWayTablePayloadResponseFut;
4973    type CallTwoWayUnionPayloadResponseFut: std::future::Future<Output = Result<UnionResultClassification, fidl::Error>>
4974        + Send;
4975    fn r#call_two_way_union_payload(
4976        &self,
4977        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
4978    ) -> Self::CallTwoWayUnionPayloadResponseFut;
4979    type CallTwoWayStructPayloadErrResponseFut: std::future::Future<Output = Result<NonEmptyResultWithErrorClassification, fidl::Error>>
4980        + Send;
4981    fn r#call_two_way_struct_payload_err(
4982        &self,
4983        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
4984    ) -> Self::CallTwoWayStructPayloadErrResponseFut;
4985    type CallTwoWayStructRequestResponseFut: std::future::Future<Output = Result<EmptyResultClassification, fidl::Error>>
4986        + Send;
4987    fn r#call_two_way_struct_request(
4988        &self,
4989        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
4990        request: &NonEmptyPayload,
4991    ) -> Self::CallTwoWayStructRequestResponseFut;
4992    type CallTwoWayTableRequestResponseFut: std::future::Future<Output = Result<EmptyResultClassification, fidl::Error>>
4993        + Send;
4994    fn r#call_two_way_table_request(
4995        &self,
4996        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
4997        request: &TablePayload,
4998    ) -> Self::CallTwoWayTableRequestResponseFut;
4999    type CallTwoWayUnionRequestResponseFut: std::future::Future<Output = Result<EmptyResultClassification, fidl::Error>>
5000        + Send;
5001    fn r#call_two_way_union_request(
5002        &self,
5003        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5004        request: &UnionPayload,
5005    ) -> Self::CallTwoWayUnionRequestResponseFut;
5006    type CallOneWayNoRequestResponseFut: std::future::Future<Output = Result<EmptyResultClassification, fidl::Error>>
5007        + Send;
5008    fn r#call_one_way_no_request(
5009        &self,
5010        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5011    ) -> Self::CallOneWayNoRequestResponseFut;
5012    type CallOneWayStructRequestResponseFut: std::future::Future<Output = Result<EmptyResultClassification, fidl::Error>>
5013        + Send;
5014    fn r#call_one_way_struct_request(
5015        &self,
5016        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5017        request: &NonEmptyPayload,
5018    ) -> Self::CallOneWayStructRequestResponseFut;
5019    type CallOneWayTableRequestResponseFut: std::future::Future<Output = Result<EmptyResultClassification, fidl::Error>>
5020        + Send;
5021    fn r#call_one_way_table_request(
5022        &self,
5023        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5024        request: &TablePayload,
5025    ) -> Self::CallOneWayTableRequestResponseFut;
5026    type CallOneWayUnionRequestResponseFut: std::future::Future<Output = Result<EmptyResultClassification, fidl::Error>>
5027        + Send;
5028    fn r#call_one_way_union_request(
5029        &self,
5030        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5031        request: &UnionPayload,
5032    ) -> Self::CallOneWayUnionRequestResponseFut;
5033    type CallStrictOneWayResponseFut: std::future::Future<Output = Result<EmptyResultClassification, fidl::Error>>
5034        + Send;
5035    fn r#call_strict_one_way(
5036        &self,
5037        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5038    ) -> Self::CallStrictOneWayResponseFut;
5039    type CallFlexibleOneWayResponseFut: std::future::Future<Output = Result<EmptyResultClassification, fidl::Error>>
5040        + Send;
5041    fn r#call_flexible_one_way(
5042        &self,
5043        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5044    ) -> Self::CallFlexibleOneWayResponseFut;
5045    type CallStrictTwoWayResponseFut: std::future::Future<Output = Result<EmptyResultClassification, fidl::Error>>
5046        + Send;
5047    fn r#call_strict_two_way(
5048        &self,
5049        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5050    ) -> Self::CallStrictTwoWayResponseFut;
5051    type CallStrictTwoWayFieldsResponseFut: std::future::Future<Output = Result<NonEmptyResultClassification, fidl::Error>>
5052        + Send;
5053    fn r#call_strict_two_way_fields(
5054        &self,
5055        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5056    ) -> Self::CallStrictTwoWayFieldsResponseFut;
5057    type CallStrictTwoWayErrResponseFut: std::future::Future<Output = Result<EmptyResultWithErrorClassification, fidl::Error>>
5058        + Send;
5059    fn r#call_strict_two_way_err(
5060        &self,
5061        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5062    ) -> Self::CallStrictTwoWayErrResponseFut;
5063    type CallStrictTwoWayFieldsErrResponseFut: std::future::Future<Output = Result<NonEmptyResultWithErrorClassification, fidl::Error>>
5064        + Send;
5065    fn r#call_strict_two_way_fields_err(
5066        &self,
5067        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5068    ) -> Self::CallStrictTwoWayFieldsErrResponseFut;
5069    type CallFlexibleTwoWayResponseFut: std::future::Future<Output = Result<EmptyResultClassification, fidl::Error>>
5070        + Send;
5071    fn r#call_flexible_two_way(
5072        &self,
5073        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5074    ) -> Self::CallFlexibleTwoWayResponseFut;
5075    type CallFlexibleTwoWayFieldsResponseFut: std::future::Future<Output = Result<NonEmptyResultClassification, fidl::Error>>
5076        + Send;
5077    fn r#call_flexible_two_way_fields(
5078        &self,
5079        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5080    ) -> Self::CallFlexibleTwoWayFieldsResponseFut;
5081    type CallFlexibleTwoWayErrResponseFut: std::future::Future<Output = Result<EmptyResultWithErrorClassification, fidl::Error>>
5082        + Send;
5083    fn r#call_flexible_two_way_err(
5084        &self,
5085        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5086    ) -> Self::CallFlexibleTwoWayErrResponseFut;
5087    type CallFlexibleTwoWayFieldsErrResponseFut: std::future::Future<Output = Result<NonEmptyResultWithErrorClassification, fidl::Error>>
5088        + Send;
5089    fn r#call_flexible_two_way_fields_err(
5090        &self,
5091        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5092    ) -> Self::CallFlexibleTwoWayFieldsErrResponseFut;
5093    type ReceiveClosedEventsResponseFut: std::future::Future<Output = Result<(), fidl::Error>>
5094        + Send;
5095    fn r#receive_closed_events(
5096        &self,
5097        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5098        reporter: fidl::endpoints::ClientEnd<ClosedTargetEventReporterMarker>,
5099    ) -> Self::ReceiveClosedEventsResponseFut;
5100    type ReceiveAjarEventsResponseFut: std::future::Future<Output = Result<(), fidl::Error>> + Send;
5101    fn r#receive_ajar_events(
5102        &self,
5103        target: fidl::endpoints::ClientEnd<AjarTargetMarker>,
5104        reporter: fidl::endpoints::ClientEnd<AjarTargetEventReporterMarker>,
5105    ) -> Self::ReceiveAjarEventsResponseFut;
5106    type ReceiveOpenEventsResponseFut: std::future::Future<Output = Result<(), fidl::Error>> + Send;
5107    fn r#receive_open_events(
5108        &self,
5109        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5110        reporter: fidl::endpoints::ClientEnd<OpenTargetEventReporterMarker>,
5111    ) -> Self::ReceiveOpenEventsResponseFut;
5112}
5113#[derive(Debug)]
5114#[cfg(target_os = "fuchsia")]
5115pub struct RunnerSynchronousProxy {
5116    client: fidl::client::sync::Client,
5117}
5118
5119#[cfg(target_os = "fuchsia")]
5120impl fidl::endpoints::SynchronousProxy for RunnerSynchronousProxy {
5121    type Proxy = RunnerProxy;
5122    type Protocol = RunnerMarker;
5123
5124    fn from_channel(inner: fidl::Channel) -> Self {
5125        Self::new(inner)
5126    }
5127
5128    fn into_channel(self) -> fidl::Channel {
5129        self.client.into_channel()
5130    }
5131
5132    fn as_channel(&self) -> &fidl::Channel {
5133        self.client.as_channel()
5134    }
5135}
5136
5137#[cfg(target_os = "fuchsia")]
5138impl RunnerSynchronousProxy {
5139    pub fn new(channel: fidl::Channel) -> Self {
5140        let protocol_name = <RunnerMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME;
5141        Self { client: fidl::client::sync::Client::new(channel, protocol_name) }
5142    }
5143
5144    pub fn into_channel(self) -> fidl::Channel {
5145        self.client.into_channel()
5146    }
5147
5148    /// Waits until an event arrives and returns it. It is safe for other
5149    /// threads to make concurrent requests while waiting for an event.
5150    pub fn wait_for_event(
5151        &self,
5152        deadline: zx::MonotonicInstant,
5153    ) -> Result<RunnerEvent, fidl::Error> {
5154        RunnerEvent::decode(self.client.wait_for_event(deadline)?)
5155    }
5156
5157    pub fn r#get_version(&self, ___deadline: zx::MonotonicInstant) -> Result<u64, fidl::Error> {
5158        let _response =
5159            self.client.send_query::<fidl::encoding::EmptyPayload, RunnerGetVersionResponse>(
5160                (),
5161                0x555d1430b913cdd4,
5162                fidl::encoding::DynamicFlags::empty(),
5163                ___deadline,
5164            )?;
5165        Ok(_response.version)
5166    }
5167
5168    pub fn r#is_test_enabled(
5169        &self,
5170        mut test: Test,
5171        ___deadline: zx::MonotonicInstant,
5172    ) -> Result<bool, fidl::Error> {
5173        let _response =
5174            self.client.send_query::<RunnerIsTestEnabledRequest, RunnerIsTestEnabledResponse>(
5175                (test,),
5176                0x755bc493368d7c50,
5177                fidl::encoding::DynamicFlags::empty(),
5178                ___deadline,
5179            )?;
5180        Ok(_response.is_enabled)
5181    }
5182
5183    pub fn r#check_alive(&self, ___deadline: zx::MonotonicInstant) -> Result<(), fidl::Error> {
5184        let _response =
5185            self.client.send_query::<fidl::encoding::EmptyPayload, fidl::encoding::EmptyPayload>(
5186                (),
5187                0x5a77b04abdfde130,
5188                fidl::encoding::DynamicFlags::empty(),
5189                ___deadline,
5190            )?;
5191        Ok(_response)
5192    }
5193
5194    pub fn r#get_bindings_properties(
5195        &self,
5196        ___deadline: zx::MonotonicInstant,
5197    ) -> Result<BindingsProperties, fidl::Error> {
5198        let _response =
5199            self.client.send_query::<fidl::encoding::EmptyPayload, BindingsProperties>(
5200                (),
5201                0x76b5610bfd4fa636,
5202                fidl::encoding::DynamicFlags::empty(),
5203                ___deadline,
5204            )?;
5205        Ok(_response)
5206    }
5207
5208    pub fn r#call_two_way_no_payload(
5209        &self,
5210        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5211        ___deadline: zx::MonotonicInstant,
5212    ) -> Result<EmptyResultClassification, fidl::Error> {
5213        let _response =
5214            self.client.send_query::<RunnerCallTwoWayNoPayloadRequest, EmptyResultClassification>(
5215                (target,),
5216                0x53ac710c20b320a1,
5217                fidl::encoding::DynamicFlags::empty(),
5218                ___deadline,
5219            )?;
5220        Ok(_response)
5221    }
5222
5223    pub fn r#call_two_way_struct_payload(
5224        &self,
5225        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5226        ___deadline: zx::MonotonicInstant,
5227    ) -> Result<NonEmptyResultClassification, fidl::Error> {
5228        let _response = self
5229            .client
5230            .send_query::<RunnerCallTwoWayStructPayloadRequest, NonEmptyResultClassification>(
5231                (target,),
5232                0x24e98c668499b946,
5233                fidl::encoding::DynamicFlags::empty(),
5234                ___deadline,
5235            )?;
5236        Ok(_response)
5237    }
5238
5239    pub fn r#call_two_way_table_payload(
5240        &self,
5241        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5242        ___deadline: zx::MonotonicInstant,
5243    ) -> Result<TableResultClassification, fidl::Error> {
5244        let _response = self
5245            .client
5246            .send_query::<RunnerCallTwoWayTablePayloadRequest, TableResultClassification>(
5247                (target,),
5248                0x72e428e1605b76a,
5249                fidl::encoding::DynamicFlags::empty(),
5250                ___deadline,
5251            )?;
5252        Ok(_response)
5253    }
5254
5255    pub fn r#call_two_way_union_payload(
5256        &self,
5257        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5258        ___deadline: zx::MonotonicInstant,
5259    ) -> Result<UnionResultClassification, fidl::Error> {
5260        let _response = self
5261            .client
5262            .send_query::<RunnerCallTwoWayUnionPayloadRequest, UnionResultClassification>(
5263                (target,),
5264                0x7dc9d67218343860,
5265                fidl::encoding::DynamicFlags::empty(),
5266                ___deadline,
5267            )?;
5268        Ok(_response)
5269    }
5270
5271    pub fn r#call_two_way_struct_payload_err(
5272        &self,
5273        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5274        ___deadline: zx::MonotonicInstant,
5275    ) -> Result<NonEmptyResultWithErrorClassification, fidl::Error> {
5276        let _response = self.client.send_query::<
5277            RunnerCallTwoWayStructPayloadErrRequest,
5278            NonEmptyResultWithErrorClassification,
5279        >(
5280            (target,),
5281            0x2b07a57942c5f6e5,
5282            fidl::encoding::DynamicFlags::empty(),
5283            ___deadline,
5284        )?;
5285        Ok(_response)
5286    }
5287
5288    pub fn r#call_two_way_struct_request(
5289        &self,
5290        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5291        mut request: &NonEmptyPayload,
5292        ___deadline: zx::MonotonicInstant,
5293    ) -> Result<EmptyResultClassification, fidl::Error> {
5294        let _response = self
5295            .client
5296            .send_query::<RunnerCallTwoWayStructRequestRequest, EmptyResultClassification>(
5297                (target, request),
5298                0x7c00a6ba2e6c9b45,
5299                fidl::encoding::DynamicFlags::empty(),
5300                ___deadline,
5301            )?;
5302        Ok(_response)
5303    }
5304
5305    pub fn r#call_two_way_table_request(
5306        &self,
5307        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5308        mut request: &TablePayload,
5309        ___deadline: zx::MonotonicInstant,
5310    ) -> Result<EmptyResultClassification, fidl::Error> {
5311        let _response = self
5312            .client
5313            .send_query::<RunnerCallTwoWayTableRequestRequest, EmptyResultClassification>(
5314                (target, request),
5315                0x641763237d3885be,
5316                fidl::encoding::DynamicFlags::empty(),
5317                ___deadline,
5318            )?;
5319        Ok(_response)
5320    }
5321
5322    pub fn r#call_two_way_union_request(
5323        &self,
5324        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5325        mut request: &UnionPayload,
5326        ___deadline: zx::MonotonicInstant,
5327    ) -> Result<EmptyResultClassification, fidl::Error> {
5328        let _response = self
5329            .client
5330            .send_query::<RunnerCallTwoWayUnionRequestRequest, EmptyResultClassification>(
5331                (target, request),
5332                0x4be5f061df42619e,
5333                fidl::encoding::DynamicFlags::empty(),
5334                ___deadline,
5335            )?;
5336        Ok(_response)
5337    }
5338
5339    pub fn r#call_one_way_no_request(
5340        &self,
5341        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5342        ___deadline: zx::MonotonicInstant,
5343    ) -> Result<EmptyResultClassification, fidl::Error> {
5344        let _response =
5345            self.client.send_query::<RunnerCallOneWayNoRequestRequest, EmptyResultClassification>(
5346                (target,),
5347                0x24b6eea8cbdccc09,
5348                fidl::encoding::DynamicFlags::empty(),
5349                ___deadline,
5350            )?;
5351        Ok(_response)
5352    }
5353
5354    pub fn r#call_one_way_struct_request(
5355        &self,
5356        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5357        mut request: &NonEmptyPayload,
5358        ___deadline: zx::MonotonicInstant,
5359    ) -> Result<EmptyResultClassification, fidl::Error> {
5360        let _response = self
5361            .client
5362            .send_query::<RunnerCallOneWayStructRequestRequest, EmptyResultClassification>(
5363                (target, request),
5364                0x352a2907a0fcb420,
5365                fidl::encoding::DynamicFlags::empty(),
5366                ___deadline,
5367            )?;
5368        Ok(_response)
5369    }
5370
5371    pub fn r#call_one_way_table_request(
5372        &self,
5373        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5374        mut request: &TablePayload,
5375        ___deadline: zx::MonotonicInstant,
5376    ) -> Result<EmptyResultClassification, fidl::Error> {
5377        let _response = self
5378            .client
5379            .send_query::<RunnerCallOneWayTableRequestRequest, EmptyResultClassification>(
5380                (target, request),
5381                0x734121bf8bf336ef,
5382                fidl::encoding::DynamicFlags::empty(),
5383                ___deadline,
5384            )?;
5385        Ok(_response)
5386    }
5387
5388    pub fn r#call_one_way_union_request(
5389        &self,
5390        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5391        mut request: &UnionPayload,
5392        ___deadline: zx::MonotonicInstant,
5393    ) -> Result<EmptyResultClassification, fidl::Error> {
5394        let _response = self
5395            .client
5396            .send_query::<RunnerCallOneWayUnionRequestRequest, EmptyResultClassification>(
5397                (target, request),
5398                0x9be8e5eb7d50eb6,
5399                fidl::encoding::DynamicFlags::empty(),
5400                ___deadline,
5401            )?;
5402        Ok(_response)
5403    }
5404
5405    pub fn r#call_strict_one_way(
5406        &self,
5407        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5408        ___deadline: zx::MonotonicInstant,
5409    ) -> Result<EmptyResultClassification, fidl::Error> {
5410        let _response =
5411            self.client.send_query::<RunnerCallStrictOneWayRequest, EmptyResultClassification>(
5412                (target,),
5413                0x4edd0b6f52c0446b,
5414                fidl::encoding::DynamicFlags::empty(),
5415                ___deadline,
5416            )?;
5417        Ok(_response)
5418    }
5419
5420    pub fn r#call_flexible_one_way(
5421        &self,
5422        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5423        ___deadline: zx::MonotonicInstant,
5424    ) -> Result<EmptyResultClassification, fidl::Error> {
5425        let _response =
5426            self.client.send_query::<RunnerCallFlexibleOneWayRequest, EmptyResultClassification>(
5427                (target,),
5428                0x7253f10a77dfe817,
5429                fidl::encoding::DynamicFlags::empty(),
5430                ___deadline,
5431            )?;
5432        Ok(_response)
5433    }
5434
5435    pub fn r#call_strict_two_way(
5436        &self,
5437        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5438        ___deadline: zx::MonotonicInstant,
5439    ) -> Result<EmptyResultClassification, fidl::Error> {
5440        let _response =
5441            self.client.send_query::<RunnerCallStrictTwoWayRequest, EmptyResultClassification>(
5442                (target,),
5443                0x1fa9fb7414aedd27,
5444                fidl::encoding::DynamicFlags::empty(),
5445                ___deadline,
5446            )?;
5447        Ok(_response)
5448    }
5449
5450    pub fn r#call_strict_two_way_fields(
5451        &self,
5452        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5453        ___deadline: zx::MonotonicInstant,
5454    ) -> Result<NonEmptyResultClassification, fidl::Error> {
5455        let _response = self
5456            .client
5457            .send_query::<RunnerCallStrictTwoWayFieldsRequest, NonEmptyResultClassification>(
5458                (target,),
5459                0x6f690e00ebf6f123,
5460                fidl::encoding::DynamicFlags::empty(),
5461                ___deadline,
5462            )?;
5463        Ok(_response)
5464    }
5465
5466    pub fn r#call_strict_two_way_err(
5467        &self,
5468        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5469        ___deadline: zx::MonotonicInstant,
5470    ) -> Result<EmptyResultWithErrorClassification, fidl::Error> {
5471        let _response = self
5472            .client
5473            .send_query::<RunnerCallStrictTwoWayErrRequest, EmptyResultWithErrorClassification>(
5474                (target,),
5475                0x51d6bc7cf6cbaf1a,
5476                fidl::encoding::DynamicFlags::empty(),
5477                ___deadline,
5478            )?;
5479        Ok(_response)
5480    }
5481
5482    pub fn r#call_strict_two_way_fields_err(
5483        &self,
5484        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5485        ___deadline: zx::MonotonicInstant,
5486    ) -> Result<NonEmptyResultWithErrorClassification, fidl::Error> {
5487        let _response = self.client.send_query::<
5488            RunnerCallStrictTwoWayFieldsErrRequest,
5489            NonEmptyResultWithErrorClassification,
5490        >(
5491            (target,),
5492            0x6fa31ced05074c05,
5493            fidl::encoding::DynamicFlags::empty(),
5494            ___deadline,
5495        )?;
5496        Ok(_response)
5497    }
5498
5499    pub fn r#call_flexible_two_way(
5500        &self,
5501        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5502        ___deadline: zx::MonotonicInstant,
5503    ) -> Result<EmptyResultClassification, fidl::Error> {
5504        let _response =
5505            self.client.send_query::<RunnerCallFlexibleTwoWayRequest, EmptyResultClassification>(
5506                (target,),
5507                0x411f70724876d49,
5508                fidl::encoding::DynamicFlags::empty(),
5509                ___deadline,
5510            )?;
5511        Ok(_response)
5512    }
5513
5514    pub fn r#call_flexible_two_way_fields(
5515        &self,
5516        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5517        ___deadline: zx::MonotonicInstant,
5518    ) -> Result<NonEmptyResultClassification, fidl::Error> {
5519        let _response = self
5520            .client
5521            .send_query::<RunnerCallFlexibleTwoWayFieldsRequest, NonEmptyResultClassification>(
5522                (target,),
5523                0x330996b623598eed,
5524                fidl::encoding::DynamicFlags::empty(),
5525                ___deadline,
5526            )?;
5527        Ok(_response)
5528    }
5529
5530    pub fn r#call_flexible_two_way_err(
5531        &self,
5532        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5533        ___deadline: zx::MonotonicInstant,
5534    ) -> Result<EmptyResultWithErrorClassification, fidl::Error> {
5535        let _response = self
5536            .client
5537            .send_query::<RunnerCallFlexibleTwoWayErrRequest, EmptyResultWithErrorClassification>(
5538                (target,),
5539                0x5ddbf88a353a2a57,
5540                fidl::encoding::DynamicFlags::empty(),
5541                ___deadline,
5542            )?;
5543        Ok(_response)
5544    }
5545
5546    pub fn r#call_flexible_two_way_fields_err(
5547        &self,
5548        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5549        ___deadline: zx::MonotonicInstant,
5550    ) -> Result<NonEmptyResultWithErrorClassification, fidl::Error> {
5551        let _response = self.client.send_query::<
5552            RunnerCallFlexibleTwoWayFieldsErrRequest,
5553            NonEmptyResultWithErrorClassification,
5554        >(
5555            (target,),
5556            0x7ae309383b07048e,
5557            fidl::encoding::DynamicFlags::empty(),
5558            ___deadline,
5559        )?;
5560        Ok(_response)
5561    }
5562
5563    pub fn r#receive_closed_events(
5564        &self,
5565        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5566        mut reporter: fidl::endpoints::ClientEnd<ClosedTargetEventReporterMarker>,
5567        ___deadline: zx::MonotonicInstant,
5568    ) -> Result<(), fidl::Error> {
5569        let _response = self
5570            .client
5571            .send_query::<RunnerReceiveClosedEventsRequest, fidl::encoding::EmptyPayload>(
5572                (target, reporter),
5573                0x48da834910571aeb,
5574                fidl::encoding::DynamicFlags::empty(),
5575                ___deadline,
5576            )?;
5577        Ok(_response)
5578    }
5579
5580    pub fn r#receive_ajar_events(
5581        &self,
5582        mut target: fidl::endpoints::ClientEnd<AjarTargetMarker>,
5583        mut reporter: fidl::endpoints::ClientEnd<AjarTargetEventReporterMarker>,
5584        ___deadline: zx::MonotonicInstant,
5585    ) -> Result<(), fidl::Error> {
5586        let _response = self
5587            .client
5588            .send_query::<RunnerReceiveAjarEventsRequest, fidl::encoding::EmptyPayload>(
5589                (target, reporter),
5590                0xc5662b9a9c007a3,
5591                fidl::encoding::DynamicFlags::empty(),
5592                ___deadline,
5593            )?;
5594        Ok(_response)
5595    }
5596
5597    pub fn r#receive_open_events(
5598        &self,
5599        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5600        mut reporter: fidl::endpoints::ClientEnd<OpenTargetEventReporterMarker>,
5601        ___deadline: zx::MonotonicInstant,
5602    ) -> Result<(), fidl::Error> {
5603        let _response = self
5604            .client
5605            .send_query::<RunnerReceiveOpenEventsRequest, fidl::encoding::EmptyPayload>(
5606                (target, reporter),
5607                0x79a7073fd18edbdf,
5608                fidl::encoding::DynamicFlags::empty(),
5609                ___deadline,
5610            )?;
5611        Ok(_response)
5612    }
5613}
5614
5615#[cfg(target_os = "fuchsia")]
5616impl From<RunnerSynchronousProxy> for zx::Handle {
5617    fn from(value: RunnerSynchronousProxy) -> Self {
5618        value.into_channel().into()
5619    }
5620}
5621
5622#[cfg(target_os = "fuchsia")]
5623impl From<fidl::Channel> for RunnerSynchronousProxy {
5624    fn from(value: fidl::Channel) -> Self {
5625        Self::new(value)
5626    }
5627}
5628
5629#[derive(Debug, Clone)]
5630pub struct RunnerProxy {
5631    client: fidl::client::Client<fidl::encoding::DefaultFuchsiaResourceDialect>,
5632}
5633
5634impl fidl::endpoints::Proxy for RunnerProxy {
5635    type Protocol = RunnerMarker;
5636
5637    fn from_channel(inner: ::fidl::AsyncChannel) -> Self {
5638        Self::new(inner)
5639    }
5640
5641    fn into_channel(self) -> Result<::fidl::AsyncChannel, Self> {
5642        self.client.into_channel().map_err(|client| Self { client })
5643    }
5644
5645    fn as_channel(&self) -> &::fidl::AsyncChannel {
5646        self.client.as_channel()
5647    }
5648}
5649
5650impl RunnerProxy {
5651    /// Create a new Proxy for fidl.clientsuite/Runner.
5652    pub fn new(channel: ::fidl::AsyncChannel) -> Self {
5653        let protocol_name = <RunnerMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME;
5654        Self { client: fidl::client::Client::new(channel, protocol_name) }
5655    }
5656
5657    /// Get a Stream of events from the remote end of the protocol.
5658    ///
5659    /// # Panics
5660    ///
5661    /// Panics if the event stream was already taken.
5662    pub fn take_event_stream(&self) -> RunnerEventStream {
5663        RunnerEventStream { event_receiver: self.client.take_event_receiver() }
5664    }
5665
5666    pub fn r#get_version(
5667        &self,
5668    ) -> fidl::client::QueryResponseFut<u64, fidl::encoding::DefaultFuchsiaResourceDialect> {
5669        RunnerProxyInterface::r#get_version(self)
5670    }
5671
5672    pub fn r#is_test_enabled(
5673        &self,
5674        mut test: Test,
5675    ) -> fidl::client::QueryResponseFut<bool, fidl::encoding::DefaultFuchsiaResourceDialect> {
5676        RunnerProxyInterface::r#is_test_enabled(self, test)
5677    }
5678
5679    pub fn r#check_alive(
5680        &self,
5681    ) -> fidl::client::QueryResponseFut<(), fidl::encoding::DefaultFuchsiaResourceDialect> {
5682        RunnerProxyInterface::r#check_alive(self)
5683    }
5684
5685    pub fn r#get_bindings_properties(
5686        &self,
5687    ) -> fidl::client::QueryResponseFut<
5688        BindingsProperties,
5689        fidl::encoding::DefaultFuchsiaResourceDialect,
5690    > {
5691        RunnerProxyInterface::r#get_bindings_properties(self)
5692    }
5693
5694    pub fn r#call_two_way_no_payload(
5695        &self,
5696        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5697    ) -> fidl::client::QueryResponseFut<
5698        EmptyResultClassification,
5699        fidl::encoding::DefaultFuchsiaResourceDialect,
5700    > {
5701        RunnerProxyInterface::r#call_two_way_no_payload(self, target)
5702    }
5703
5704    pub fn r#call_two_way_struct_payload(
5705        &self,
5706        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5707    ) -> fidl::client::QueryResponseFut<
5708        NonEmptyResultClassification,
5709        fidl::encoding::DefaultFuchsiaResourceDialect,
5710    > {
5711        RunnerProxyInterface::r#call_two_way_struct_payload(self, target)
5712    }
5713
5714    pub fn r#call_two_way_table_payload(
5715        &self,
5716        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5717    ) -> fidl::client::QueryResponseFut<
5718        TableResultClassification,
5719        fidl::encoding::DefaultFuchsiaResourceDialect,
5720    > {
5721        RunnerProxyInterface::r#call_two_way_table_payload(self, target)
5722    }
5723
5724    pub fn r#call_two_way_union_payload(
5725        &self,
5726        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5727    ) -> fidl::client::QueryResponseFut<
5728        UnionResultClassification,
5729        fidl::encoding::DefaultFuchsiaResourceDialect,
5730    > {
5731        RunnerProxyInterface::r#call_two_way_union_payload(self, target)
5732    }
5733
5734    pub fn r#call_two_way_struct_payload_err(
5735        &self,
5736        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5737    ) -> fidl::client::QueryResponseFut<
5738        NonEmptyResultWithErrorClassification,
5739        fidl::encoding::DefaultFuchsiaResourceDialect,
5740    > {
5741        RunnerProxyInterface::r#call_two_way_struct_payload_err(self, target)
5742    }
5743
5744    pub fn r#call_two_way_struct_request(
5745        &self,
5746        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5747        mut request: &NonEmptyPayload,
5748    ) -> fidl::client::QueryResponseFut<
5749        EmptyResultClassification,
5750        fidl::encoding::DefaultFuchsiaResourceDialect,
5751    > {
5752        RunnerProxyInterface::r#call_two_way_struct_request(self, target, request)
5753    }
5754
5755    pub fn r#call_two_way_table_request(
5756        &self,
5757        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5758        mut request: &TablePayload,
5759    ) -> fidl::client::QueryResponseFut<
5760        EmptyResultClassification,
5761        fidl::encoding::DefaultFuchsiaResourceDialect,
5762    > {
5763        RunnerProxyInterface::r#call_two_way_table_request(self, target, request)
5764    }
5765
5766    pub fn r#call_two_way_union_request(
5767        &self,
5768        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5769        mut request: &UnionPayload,
5770    ) -> fidl::client::QueryResponseFut<
5771        EmptyResultClassification,
5772        fidl::encoding::DefaultFuchsiaResourceDialect,
5773    > {
5774        RunnerProxyInterface::r#call_two_way_union_request(self, target, request)
5775    }
5776
5777    pub fn r#call_one_way_no_request(
5778        &self,
5779        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5780    ) -> fidl::client::QueryResponseFut<
5781        EmptyResultClassification,
5782        fidl::encoding::DefaultFuchsiaResourceDialect,
5783    > {
5784        RunnerProxyInterface::r#call_one_way_no_request(self, target)
5785    }
5786
5787    pub fn r#call_one_way_struct_request(
5788        &self,
5789        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5790        mut request: &NonEmptyPayload,
5791    ) -> fidl::client::QueryResponseFut<
5792        EmptyResultClassification,
5793        fidl::encoding::DefaultFuchsiaResourceDialect,
5794    > {
5795        RunnerProxyInterface::r#call_one_way_struct_request(self, target, request)
5796    }
5797
5798    pub fn r#call_one_way_table_request(
5799        &self,
5800        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5801        mut request: &TablePayload,
5802    ) -> fidl::client::QueryResponseFut<
5803        EmptyResultClassification,
5804        fidl::encoding::DefaultFuchsiaResourceDialect,
5805    > {
5806        RunnerProxyInterface::r#call_one_way_table_request(self, target, request)
5807    }
5808
5809    pub fn r#call_one_way_union_request(
5810        &self,
5811        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5812        mut request: &UnionPayload,
5813    ) -> fidl::client::QueryResponseFut<
5814        EmptyResultClassification,
5815        fidl::encoding::DefaultFuchsiaResourceDialect,
5816    > {
5817        RunnerProxyInterface::r#call_one_way_union_request(self, target, request)
5818    }
5819
5820    pub fn r#call_strict_one_way(
5821        &self,
5822        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5823    ) -> fidl::client::QueryResponseFut<
5824        EmptyResultClassification,
5825        fidl::encoding::DefaultFuchsiaResourceDialect,
5826    > {
5827        RunnerProxyInterface::r#call_strict_one_way(self, target)
5828    }
5829
5830    pub fn r#call_flexible_one_way(
5831        &self,
5832        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5833    ) -> fidl::client::QueryResponseFut<
5834        EmptyResultClassification,
5835        fidl::encoding::DefaultFuchsiaResourceDialect,
5836    > {
5837        RunnerProxyInterface::r#call_flexible_one_way(self, target)
5838    }
5839
5840    pub fn r#call_strict_two_way(
5841        &self,
5842        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5843    ) -> fidl::client::QueryResponseFut<
5844        EmptyResultClassification,
5845        fidl::encoding::DefaultFuchsiaResourceDialect,
5846    > {
5847        RunnerProxyInterface::r#call_strict_two_way(self, target)
5848    }
5849
5850    pub fn r#call_strict_two_way_fields(
5851        &self,
5852        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5853    ) -> fidl::client::QueryResponseFut<
5854        NonEmptyResultClassification,
5855        fidl::encoding::DefaultFuchsiaResourceDialect,
5856    > {
5857        RunnerProxyInterface::r#call_strict_two_way_fields(self, target)
5858    }
5859
5860    pub fn r#call_strict_two_way_err(
5861        &self,
5862        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5863    ) -> fidl::client::QueryResponseFut<
5864        EmptyResultWithErrorClassification,
5865        fidl::encoding::DefaultFuchsiaResourceDialect,
5866    > {
5867        RunnerProxyInterface::r#call_strict_two_way_err(self, target)
5868    }
5869
5870    pub fn r#call_strict_two_way_fields_err(
5871        &self,
5872        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5873    ) -> fidl::client::QueryResponseFut<
5874        NonEmptyResultWithErrorClassification,
5875        fidl::encoding::DefaultFuchsiaResourceDialect,
5876    > {
5877        RunnerProxyInterface::r#call_strict_two_way_fields_err(self, target)
5878    }
5879
5880    pub fn r#call_flexible_two_way(
5881        &self,
5882        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5883    ) -> fidl::client::QueryResponseFut<
5884        EmptyResultClassification,
5885        fidl::encoding::DefaultFuchsiaResourceDialect,
5886    > {
5887        RunnerProxyInterface::r#call_flexible_two_way(self, target)
5888    }
5889
5890    pub fn r#call_flexible_two_way_fields(
5891        &self,
5892        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5893    ) -> fidl::client::QueryResponseFut<
5894        NonEmptyResultClassification,
5895        fidl::encoding::DefaultFuchsiaResourceDialect,
5896    > {
5897        RunnerProxyInterface::r#call_flexible_two_way_fields(self, target)
5898    }
5899
5900    pub fn r#call_flexible_two_way_err(
5901        &self,
5902        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5903    ) -> fidl::client::QueryResponseFut<
5904        EmptyResultWithErrorClassification,
5905        fidl::encoding::DefaultFuchsiaResourceDialect,
5906    > {
5907        RunnerProxyInterface::r#call_flexible_two_way_err(self, target)
5908    }
5909
5910    pub fn r#call_flexible_two_way_fields_err(
5911        &self,
5912        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5913    ) -> fidl::client::QueryResponseFut<
5914        NonEmptyResultWithErrorClassification,
5915        fidl::encoding::DefaultFuchsiaResourceDialect,
5916    > {
5917        RunnerProxyInterface::r#call_flexible_two_way_fields_err(self, target)
5918    }
5919
5920    pub fn r#receive_closed_events(
5921        &self,
5922        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
5923        mut reporter: fidl::endpoints::ClientEnd<ClosedTargetEventReporterMarker>,
5924    ) -> fidl::client::QueryResponseFut<(), fidl::encoding::DefaultFuchsiaResourceDialect> {
5925        RunnerProxyInterface::r#receive_closed_events(self, target, reporter)
5926    }
5927
5928    pub fn r#receive_ajar_events(
5929        &self,
5930        mut target: fidl::endpoints::ClientEnd<AjarTargetMarker>,
5931        mut reporter: fidl::endpoints::ClientEnd<AjarTargetEventReporterMarker>,
5932    ) -> fidl::client::QueryResponseFut<(), fidl::encoding::DefaultFuchsiaResourceDialect> {
5933        RunnerProxyInterface::r#receive_ajar_events(self, target, reporter)
5934    }
5935
5936    pub fn r#receive_open_events(
5937        &self,
5938        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
5939        mut reporter: fidl::endpoints::ClientEnd<OpenTargetEventReporterMarker>,
5940    ) -> fidl::client::QueryResponseFut<(), fidl::encoding::DefaultFuchsiaResourceDialect> {
5941        RunnerProxyInterface::r#receive_open_events(self, target, reporter)
5942    }
5943}
5944
5945impl RunnerProxyInterface for RunnerProxy {
5946    type GetVersionResponseFut =
5947        fidl::client::QueryResponseFut<u64, fidl::encoding::DefaultFuchsiaResourceDialect>;
5948    fn r#get_version(&self) -> Self::GetVersionResponseFut {
5949        fn _decode(
5950            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
5951        ) -> Result<u64, fidl::Error> {
5952            let _response = fidl::client::decode_transaction_body::<
5953                RunnerGetVersionResponse,
5954                fidl::encoding::DefaultFuchsiaResourceDialect,
5955                0x555d1430b913cdd4,
5956            >(_buf?)?;
5957            Ok(_response.version)
5958        }
5959        self.client.send_query_and_decode::<fidl::encoding::EmptyPayload, u64>(
5960            (),
5961            0x555d1430b913cdd4,
5962            fidl::encoding::DynamicFlags::empty(),
5963            _decode,
5964        )
5965    }
5966
5967    type IsTestEnabledResponseFut =
5968        fidl::client::QueryResponseFut<bool, fidl::encoding::DefaultFuchsiaResourceDialect>;
5969    fn r#is_test_enabled(&self, mut test: Test) -> Self::IsTestEnabledResponseFut {
5970        fn _decode(
5971            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
5972        ) -> Result<bool, fidl::Error> {
5973            let _response = fidl::client::decode_transaction_body::<
5974                RunnerIsTestEnabledResponse,
5975                fidl::encoding::DefaultFuchsiaResourceDialect,
5976                0x755bc493368d7c50,
5977            >(_buf?)?;
5978            Ok(_response.is_enabled)
5979        }
5980        self.client.send_query_and_decode::<RunnerIsTestEnabledRequest, bool>(
5981            (test,),
5982            0x755bc493368d7c50,
5983            fidl::encoding::DynamicFlags::empty(),
5984            _decode,
5985        )
5986    }
5987
5988    type CheckAliveResponseFut =
5989        fidl::client::QueryResponseFut<(), fidl::encoding::DefaultFuchsiaResourceDialect>;
5990    fn r#check_alive(&self) -> Self::CheckAliveResponseFut {
5991        fn _decode(
5992            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
5993        ) -> Result<(), fidl::Error> {
5994            let _response = fidl::client::decode_transaction_body::<
5995                fidl::encoding::EmptyPayload,
5996                fidl::encoding::DefaultFuchsiaResourceDialect,
5997                0x5a77b04abdfde130,
5998            >(_buf?)?;
5999            Ok(_response)
6000        }
6001        self.client.send_query_and_decode::<fidl::encoding::EmptyPayload, ()>(
6002            (),
6003            0x5a77b04abdfde130,
6004            fidl::encoding::DynamicFlags::empty(),
6005            _decode,
6006        )
6007    }
6008
6009    type GetBindingsPropertiesResponseFut = fidl::client::QueryResponseFut<
6010        BindingsProperties,
6011        fidl::encoding::DefaultFuchsiaResourceDialect,
6012    >;
6013    fn r#get_bindings_properties(&self) -> Self::GetBindingsPropertiesResponseFut {
6014        fn _decode(
6015            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6016        ) -> Result<BindingsProperties, fidl::Error> {
6017            let _response = fidl::client::decode_transaction_body::<
6018                BindingsProperties,
6019                fidl::encoding::DefaultFuchsiaResourceDialect,
6020                0x76b5610bfd4fa636,
6021            >(_buf?)?;
6022            Ok(_response)
6023        }
6024        self.client.send_query_and_decode::<fidl::encoding::EmptyPayload, BindingsProperties>(
6025            (),
6026            0x76b5610bfd4fa636,
6027            fidl::encoding::DynamicFlags::empty(),
6028            _decode,
6029        )
6030    }
6031
6032    type CallTwoWayNoPayloadResponseFut = fidl::client::QueryResponseFut<
6033        EmptyResultClassification,
6034        fidl::encoding::DefaultFuchsiaResourceDialect,
6035    >;
6036    fn r#call_two_way_no_payload(
6037        &self,
6038        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
6039    ) -> Self::CallTwoWayNoPayloadResponseFut {
6040        fn _decode(
6041            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6042        ) -> Result<EmptyResultClassification, fidl::Error> {
6043            let _response = fidl::client::decode_transaction_body::<
6044                EmptyResultClassification,
6045                fidl::encoding::DefaultFuchsiaResourceDialect,
6046                0x53ac710c20b320a1,
6047            >(_buf?)?;
6048            Ok(_response)
6049        }
6050        self.client
6051            .send_query_and_decode::<RunnerCallTwoWayNoPayloadRequest, EmptyResultClassification>(
6052                (target,),
6053                0x53ac710c20b320a1,
6054                fidl::encoding::DynamicFlags::empty(),
6055                _decode,
6056            )
6057    }
6058
6059    type CallTwoWayStructPayloadResponseFut = fidl::client::QueryResponseFut<
6060        NonEmptyResultClassification,
6061        fidl::encoding::DefaultFuchsiaResourceDialect,
6062    >;
6063    fn r#call_two_way_struct_payload(
6064        &self,
6065        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
6066    ) -> Self::CallTwoWayStructPayloadResponseFut {
6067        fn _decode(
6068            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6069        ) -> Result<NonEmptyResultClassification, fidl::Error> {
6070            let _response = fidl::client::decode_transaction_body::<
6071                NonEmptyResultClassification,
6072                fidl::encoding::DefaultFuchsiaResourceDialect,
6073                0x24e98c668499b946,
6074            >(_buf?)?;
6075            Ok(_response)
6076        }
6077        self.client.send_query_and_decode::<
6078            RunnerCallTwoWayStructPayloadRequest,
6079            NonEmptyResultClassification,
6080        >(
6081            (target,),
6082            0x24e98c668499b946,
6083            fidl::encoding::DynamicFlags::empty(),
6084            _decode,
6085        )
6086    }
6087
6088    type CallTwoWayTablePayloadResponseFut = fidl::client::QueryResponseFut<
6089        TableResultClassification,
6090        fidl::encoding::DefaultFuchsiaResourceDialect,
6091    >;
6092    fn r#call_two_way_table_payload(
6093        &self,
6094        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
6095    ) -> Self::CallTwoWayTablePayloadResponseFut {
6096        fn _decode(
6097            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6098        ) -> Result<TableResultClassification, fidl::Error> {
6099            let _response = fidl::client::decode_transaction_body::<
6100                TableResultClassification,
6101                fidl::encoding::DefaultFuchsiaResourceDialect,
6102                0x72e428e1605b76a,
6103            >(_buf?)?;
6104            Ok(_response)
6105        }
6106        self.client.send_query_and_decode::<
6107            RunnerCallTwoWayTablePayloadRequest,
6108            TableResultClassification,
6109        >(
6110            (target,),
6111            0x72e428e1605b76a,
6112            fidl::encoding::DynamicFlags::empty(),
6113            _decode,
6114        )
6115    }
6116
6117    type CallTwoWayUnionPayloadResponseFut = fidl::client::QueryResponseFut<
6118        UnionResultClassification,
6119        fidl::encoding::DefaultFuchsiaResourceDialect,
6120    >;
6121    fn r#call_two_way_union_payload(
6122        &self,
6123        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
6124    ) -> Self::CallTwoWayUnionPayloadResponseFut {
6125        fn _decode(
6126            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6127        ) -> Result<UnionResultClassification, fidl::Error> {
6128            let _response = fidl::client::decode_transaction_body::<
6129                UnionResultClassification,
6130                fidl::encoding::DefaultFuchsiaResourceDialect,
6131                0x7dc9d67218343860,
6132            >(_buf?)?;
6133            Ok(_response)
6134        }
6135        self.client.send_query_and_decode::<
6136            RunnerCallTwoWayUnionPayloadRequest,
6137            UnionResultClassification,
6138        >(
6139            (target,),
6140            0x7dc9d67218343860,
6141            fidl::encoding::DynamicFlags::empty(),
6142            _decode,
6143        )
6144    }
6145
6146    type CallTwoWayStructPayloadErrResponseFut = fidl::client::QueryResponseFut<
6147        NonEmptyResultWithErrorClassification,
6148        fidl::encoding::DefaultFuchsiaResourceDialect,
6149    >;
6150    fn r#call_two_way_struct_payload_err(
6151        &self,
6152        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
6153    ) -> Self::CallTwoWayStructPayloadErrResponseFut {
6154        fn _decode(
6155            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6156        ) -> Result<NonEmptyResultWithErrorClassification, fidl::Error> {
6157            let _response = fidl::client::decode_transaction_body::<
6158                NonEmptyResultWithErrorClassification,
6159                fidl::encoding::DefaultFuchsiaResourceDialect,
6160                0x2b07a57942c5f6e5,
6161            >(_buf?)?;
6162            Ok(_response)
6163        }
6164        self.client.send_query_and_decode::<
6165            RunnerCallTwoWayStructPayloadErrRequest,
6166            NonEmptyResultWithErrorClassification,
6167        >(
6168            (target,),
6169            0x2b07a57942c5f6e5,
6170            fidl::encoding::DynamicFlags::empty(),
6171            _decode,
6172        )
6173    }
6174
6175    type CallTwoWayStructRequestResponseFut = fidl::client::QueryResponseFut<
6176        EmptyResultClassification,
6177        fidl::encoding::DefaultFuchsiaResourceDialect,
6178    >;
6179    fn r#call_two_way_struct_request(
6180        &self,
6181        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
6182        mut request: &NonEmptyPayload,
6183    ) -> Self::CallTwoWayStructRequestResponseFut {
6184        fn _decode(
6185            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6186        ) -> Result<EmptyResultClassification, fidl::Error> {
6187            let _response = fidl::client::decode_transaction_body::<
6188                EmptyResultClassification,
6189                fidl::encoding::DefaultFuchsiaResourceDialect,
6190                0x7c00a6ba2e6c9b45,
6191            >(_buf?)?;
6192            Ok(_response)
6193        }
6194        self.client.send_query_and_decode::<
6195            RunnerCallTwoWayStructRequestRequest,
6196            EmptyResultClassification,
6197        >(
6198            (target, request,),
6199            0x7c00a6ba2e6c9b45,
6200            fidl::encoding::DynamicFlags::empty(),
6201            _decode,
6202        )
6203    }
6204
6205    type CallTwoWayTableRequestResponseFut = fidl::client::QueryResponseFut<
6206        EmptyResultClassification,
6207        fidl::encoding::DefaultFuchsiaResourceDialect,
6208    >;
6209    fn r#call_two_way_table_request(
6210        &self,
6211        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
6212        mut request: &TablePayload,
6213    ) -> Self::CallTwoWayTableRequestResponseFut {
6214        fn _decode(
6215            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6216        ) -> Result<EmptyResultClassification, fidl::Error> {
6217            let _response = fidl::client::decode_transaction_body::<
6218                EmptyResultClassification,
6219                fidl::encoding::DefaultFuchsiaResourceDialect,
6220                0x641763237d3885be,
6221            >(_buf?)?;
6222            Ok(_response)
6223        }
6224        self.client.send_query_and_decode::<
6225            RunnerCallTwoWayTableRequestRequest,
6226            EmptyResultClassification,
6227        >(
6228            (target, request,),
6229            0x641763237d3885be,
6230            fidl::encoding::DynamicFlags::empty(),
6231            _decode,
6232        )
6233    }
6234
6235    type CallTwoWayUnionRequestResponseFut = fidl::client::QueryResponseFut<
6236        EmptyResultClassification,
6237        fidl::encoding::DefaultFuchsiaResourceDialect,
6238    >;
6239    fn r#call_two_way_union_request(
6240        &self,
6241        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
6242        mut request: &UnionPayload,
6243    ) -> Self::CallTwoWayUnionRequestResponseFut {
6244        fn _decode(
6245            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6246        ) -> Result<EmptyResultClassification, fidl::Error> {
6247            let _response = fidl::client::decode_transaction_body::<
6248                EmptyResultClassification,
6249                fidl::encoding::DefaultFuchsiaResourceDialect,
6250                0x4be5f061df42619e,
6251            >(_buf?)?;
6252            Ok(_response)
6253        }
6254        self.client.send_query_and_decode::<
6255            RunnerCallTwoWayUnionRequestRequest,
6256            EmptyResultClassification,
6257        >(
6258            (target, request,),
6259            0x4be5f061df42619e,
6260            fidl::encoding::DynamicFlags::empty(),
6261            _decode,
6262        )
6263    }
6264
6265    type CallOneWayNoRequestResponseFut = fidl::client::QueryResponseFut<
6266        EmptyResultClassification,
6267        fidl::encoding::DefaultFuchsiaResourceDialect,
6268    >;
6269    fn r#call_one_way_no_request(
6270        &self,
6271        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
6272    ) -> Self::CallOneWayNoRequestResponseFut {
6273        fn _decode(
6274            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6275        ) -> Result<EmptyResultClassification, fidl::Error> {
6276            let _response = fidl::client::decode_transaction_body::<
6277                EmptyResultClassification,
6278                fidl::encoding::DefaultFuchsiaResourceDialect,
6279                0x24b6eea8cbdccc09,
6280            >(_buf?)?;
6281            Ok(_response)
6282        }
6283        self.client
6284            .send_query_and_decode::<RunnerCallOneWayNoRequestRequest, EmptyResultClassification>(
6285                (target,),
6286                0x24b6eea8cbdccc09,
6287                fidl::encoding::DynamicFlags::empty(),
6288                _decode,
6289            )
6290    }
6291
6292    type CallOneWayStructRequestResponseFut = fidl::client::QueryResponseFut<
6293        EmptyResultClassification,
6294        fidl::encoding::DefaultFuchsiaResourceDialect,
6295    >;
6296    fn r#call_one_way_struct_request(
6297        &self,
6298        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
6299        mut request: &NonEmptyPayload,
6300    ) -> Self::CallOneWayStructRequestResponseFut {
6301        fn _decode(
6302            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6303        ) -> Result<EmptyResultClassification, fidl::Error> {
6304            let _response = fidl::client::decode_transaction_body::<
6305                EmptyResultClassification,
6306                fidl::encoding::DefaultFuchsiaResourceDialect,
6307                0x352a2907a0fcb420,
6308            >(_buf?)?;
6309            Ok(_response)
6310        }
6311        self.client.send_query_and_decode::<
6312            RunnerCallOneWayStructRequestRequest,
6313            EmptyResultClassification,
6314        >(
6315            (target, request,),
6316            0x352a2907a0fcb420,
6317            fidl::encoding::DynamicFlags::empty(),
6318            _decode,
6319        )
6320    }
6321
6322    type CallOneWayTableRequestResponseFut = fidl::client::QueryResponseFut<
6323        EmptyResultClassification,
6324        fidl::encoding::DefaultFuchsiaResourceDialect,
6325    >;
6326    fn r#call_one_way_table_request(
6327        &self,
6328        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
6329        mut request: &TablePayload,
6330    ) -> Self::CallOneWayTableRequestResponseFut {
6331        fn _decode(
6332            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6333        ) -> Result<EmptyResultClassification, fidl::Error> {
6334            let _response = fidl::client::decode_transaction_body::<
6335                EmptyResultClassification,
6336                fidl::encoding::DefaultFuchsiaResourceDialect,
6337                0x734121bf8bf336ef,
6338            >(_buf?)?;
6339            Ok(_response)
6340        }
6341        self.client.send_query_and_decode::<
6342            RunnerCallOneWayTableRequestRequest,
6343            EmptyResultClassification,
6344        >(
6345            (target, request,),
6346            0x734121bf8bf336ef,
6347            fidl::encoding::DynamicFlags::empty(),
6348            _decode,
6349        )
6350    }
6351
6352    type CallOneWayUnionRequestResponseFut = fidl::client::QueryResponseFut<
6353        EmptyResultClassification,
6354        fidl::encoding::DefaultFuchsiaResourceDialect,
6355    >;
6356    fn r#call_one_way_union_request(
6357        &self,
6358        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
6359        mut request: &UnionPayload,
6360    ) -> Self::CallOneWayUnionRequestResponseFut {
6361        fn _decode(
6362            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6363        ) -> Result<EmptyResultClassification, fidl::Error> {
6364            let _response = fidl::client::decode_transaction_body::<
6365                EmptyResultClassification,
6366                fidl::encoding::DefaultFuchsiaResourceDialect,
6367                0x9be8e5eb7d50eb6,
6368            >(_buf?)?;
6369            Ok(_response)
6370        }
6371        self.client.send_query_and_decode::<
6372            RunnerCallOneWayUnionRequestRequest,
6373            EmptyResultClassification,
6374        >(
6375            (target, request,),
6376            0x9be8e5eb7d50eb6,
6377            fidl::encoding::DynamicFlags::empty(),
6378            _decode,
6379        )
6380    }
6381
6382    type CallStrictOneWayResponseFut = fidl::client::QueryResponseFut<
6383        EmptyResultClassification,
6384        fidl::encoding::DefaultFuchsiaResourceDialect,
6385    >;
6386    fn r#call_strict_one_way(
6387        &self,
6388        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
6389    ) -> Self::CallStrictOneWayResponseFut {
6390        fn _decode(
6391            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6392        ) -> Result<EmptyResultClassification, fidl::Error> {
6393            let _response = fidl::client::decode_transaction_body::<
6394                EmptyResultClassification,
6395                fidl::encoding::DefaultFuchsiaResourceDialect,
6396                0x4edd0b6f52c0446b,
6397            >(_buf?)?;
6398            Ok(_response)
6399        }
6400        self.client
6401            .send_query_and_decode::<RunnerCallStrictOneWayRequest, EmptyResultClassification>(
6402                (target,),
6403                0x4edd0b6f52c0446b,
6404                fidl::encoding::DynamicFlags::empty(),
6405                _decode,
6406            )
6407    }
6408
6409    type CallFlexibleOneWayResponseFut = fidl::client::QueryResponseFut<
6410        EmptyResultClassification,
6411        fidl::encoding::DefaultFuchsiaResourceDialect,
6412    >;
6413    fn r#call_flexible_one_way(
6414        &self,
6415        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
6416    ) -> Self::CallFlexibleOneWayResponseFut {
6417        fn _decode(
6418            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6419        ) -> Result<EmptyResultClassification, fidl::Error> {
6420            let _response = fidl::client::decode_transaction_body::<
6421                EmptyResultClassification,
6422                fidl::encoding::DefaultFuchsiaResourceDialect,
6423                0x7253f10a77dfe817,
6424            >(_buf?)?;
6425            Ok(_response)
6426        }
6427        self.client
6428            .send_query_and_decode::<RunnerCallFlexibleOneWayRequest, EmptyResultClassification>(
6429                (target,),
6430                0x7253f10a77dfe817,
6431                fidl::encoding::DynamicFlags::empty(),
6432                _decode,
6433            )
6434    }
6435
6436    type CallStrictTwoWayResponseFut = fidl::client::QueryResponseFut<
6437        EmptyResultClassification,
6438        fidl::encoding::DefaultFuchsiaResourceDialect,
6439    >;
6440    fn r#call_strict_two_way(
6441        &self,
6442        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
6443    ) -> Self::CallStrictTwoWayResponseFut {
6444        fn _decode(
6445            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6446        ) -> Result<EmptyResultClassification, fidl::Error> {
6447            let _response = fidl::client::decode_transaction_body::<
6448                EmptyResultClassification,
6449                fidl::encoding::DefaultFuchsiaResourceDialect,
6450                0x1fa9fb7414aedd27,
6451            >(_buf?)?;
6452            Ok(_response)
6453        }
6454        self.client
6455            .send_query_and_decode::<RunnerCallStrictTwoWayRequest, EmptyResultClassification>(
6456                (target,),
6457                0x1fa9fb7414aedd27,
6458                fidl::encoding::DynamicFlags::empty(),
6459                _decode,
6460            )
6461    }
6462
6463    type CallStrictTwoWayFieldsResponseFut = fidl::client::QueryResponseFut<
6464        NonEmptyResultClassification,
6465        fidl::encoding::DefaultFuchsiaResourceDialect,
6466    >;
6467    fn r#call_strict_two_way_fields(
6468        &self,
6469        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
6470    ) -> Self::CallStrictTwoWayFieldsResponseFut {
6471        fn _decode(
6472            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6473        ) -> Result<NonEmptyResultClassification, fidl::Error> {
6474            let _response = fidl::client::decode_transaction_body::<
6475                NonEmptyResultClassification,
6476                fidl::encoding::DefaultFuchsiaResourceDialect,
6477                0x6f690e00ebf6f123,
6478            >(_buf?)?;
6479            Ok(_response)
6480        }
6481        self.client.send_query_and_decode::<
6482            RunnerCallStrictTwoWayFieldsRequest,
6483            NonEmptyResultClassification,
6484        >(
6485            (target,),
6486            0x6f690e00ebf6f123,
6487            fidl::encoding::DynamicFlags::empty(),
6488            _decode,
6489        )
6490    }
6491
6492    type CallStrictTwoWayErrResponseFut = fidl::client::QueryResponseFut<
6493        EmptyResultWithErrorClassification,
6494        fidl::encoding::DefaultFuchsiaResourceDialect,
6495    >;
6496    fn r#call_strict_two_way_err(
6497        &self,
6498        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
6499    ) -> Self::CallStrictTwoWayErrResponseFut {
6500        fn _decode(
6501            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6502        ) -> Result<EmptyResultWithErrorClassification, fidl::Error> {
6503            let _response = fidl::client::decode_transaction_body::<
6504                EmptyResultWithErrorClassification,
6505                fidl::encoding::DefaultFuchsiaResourceDialect,
6506                0x51d6bc7cf6cbaf1a,
6507            >(_buf?)?;
6508            Ok(_response)
6509        }
6510        self.client.send_query_and_decode::<
6511            RunnerCallStrictTwoWayErrRequest,
6512            EmptyResultWithErrorClassification,
6513        >(
6514            (target,),
6515            0x51d6bc7cf6cbaf1a,
6516            fidl::encoding::DynamicFlags::empty(),
6517            _decode,
6518        )
6519    }
6520
6521    type CallStrictTwoWayFieldsErrResponseFut = fidl::client::QueryResponseFut<
6522        NonEmptyResultWithErrorClassification,
6523        fidl::encoding::DefaultFuchsiaResourceDialect,
6524    >;
6525    fn r#call_strict_two_way_fields_err(
6526        &self,
6527        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
6528    ) -> Self::CallStrictTwoWayFieldsErrResponseFut {
6529        fn _decode(
6530            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6531        ) -> Result<NonEmptyResultWithErrorClassification, fidl::Error> {
6532            let _response = fidl::client::decode_transaction_body::<
6533                NonEmptyResultWithErrorClassification,
6534                fidl::encoding::DefaultFuchsiaResourceDialect,
6535                0x6fa31ced05074c05,
6536            >(_buf?)?;
6537            Ok(_response)
6538        }
6539        self.client.send_query_and_decode::<
6540            RunnerCallStrictTwoWayFieldsErrRequest,
6541            NonEmptyResultWithErrorClassification,
6542        >(
6543            (target,),
6544            0x6fa31ced05074c05,
6545            fidl::encoding::DynamicFlags::empty(),
6546            _decode,
6547        )
6548    }
6549
6550    type CallFlexibleTwoWayResponseFut = fidl::client::QueryResponseFut<
6551        EmptyResultClassification,
6552        fidl::encoding::DefaultFuchsiaResourceDialect,
6553    >;
6554    fn r#call_flexible_two_way(
6555        &self,
6556        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
6557    ) -> Self::CallFlexibleTwoWayResponseFut {
6558        fn _decode(
6559            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6560        ) -> Result<EmptyResultClassification, fidl::Error> {
6561            let _response = fidl::client::decode_transaction_body::<
6562                EmptyResultClassification,
6563                fidl::encoding::DefaultFuchsiaResourceDialect,
6564                0x411f70724876d49,
6565            >(_buf?)?;
6566            Ok(_response)
6567        }
6568        self.client
6569            .send_query_and_decode::<RunnerCallFlexibleTwoWayRequest, EmptyResultClassification>(
6570                (target,),
6571                0x411f70724876d49,
6572                fidl::encoding::DynamicFlags::empty(),
6573                _decode,
6574            )
6575    }
6576
6577    type CallFlexibleTwoWayFieldsResponseFut = fidl::client::QueryResponseFut<
6578        NonEmptyResultClassification,
6579        fidl::encoding::DefaultFuchsiaResourceDialect,
6580    >;
6581    fn r#call_flexible_two_way_fields(
6582        &self,
6583        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
6584    ) -> Self::CallFlexibleTwoWayFieldsResponseFut {
6585        fn _decode(
6586            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6587        ) -> Result<NonEmptyResultClassification, fidl::Error> {
6588            let _response = fidl::client::decode_transaction_body::<
6589                NonEmptyResultClassification,
6590                fidl::encoding::DefaultFuchsiaResourceDialect,
6591                0x330996b623598eed,
6592            >(_buf?)?;
6593            Ok(_response)
6594        }
6595        self.client.send_query_and_decode::<
6596            RunnerCallFlexibleTwoWayFieldsRequest,
6597            NonEmptyResultClassification,
6598        >(
6599            (target,),
6600            0x330996b623598eed,
6601            fidl::encoding::DynamicFlags::empty(),
6602            _decode,
6603        )
6604    }
6605
6606    type CallFlexibleTwoWayErrResponseFut = fidl::client::QueryResponseFut<
6607        EmptyResultWithErrorClassification,
6608        fidl::encoding::DefaultFuchsiaResourceDialect,
6609    >;
6610    fn r#call_flexible_two_way_err(
6611        &self,
6612        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
6613    ) -> Self::CallFlexibleTwoWayErrResponseFut {
6614        fn _decode(
6615            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6616        ) -> Result<EmptyResultWithErrorClassification, fidl::Error> {
6617            let _response = fidl::client::decode_transaction_body::<
6618                EmptyResultWithErrorClassification,
6619                fidl::encoding::DefaultFuchsiaResourceDialect,
6620                0x5ddbf88a353a2a57,
6621            >(_buf?)?;
6622            Ok(_response)
6623        }
6624        self.client.send_query_and_decode::<
6625            RunnerCallFlexibleTwoWayErrRequest,
6626            EmptyResultWithErrorClassification,
6627        >(
6628            (target,),
6629            0x5ddbf88a353a2a57,
6630            fidl::encoding::DynamicFlags::empty(),
6631            _decode,
6632        )
6633    }
6634
6635    type CallFlexibleTwoWayFieldsErrResponseFut = fidl::client::QueryResponseFut<
6636        NonEmptyResultWithErrorClassification,
6637        fidl::encoding::DefaultFuchsiaResourceDialect,
6638    >;
6639    fn r#call_flexible_two_way_fields_err(
6640        &self,
6641        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
6642    ) -> Self::CallFlexibleTwoWayFieldsErrResponseFut {
6643        fn _decode(
6644            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6645        ) -> Result<NonEmptyResultWithErrorClassification, fidl::Error> {
6646            let _response = fidl::client::decode_transaction_body::<
6647                NonEmptyResultWithErrorClassification,
6648                fidl::encoding::DefaultFuchsiaResourceDialect,
6649                0x7ae309383b07048e,
6650            >(_buf?)?;
6651            Ok(_response)
6652        }
6653        self.client.send_query_and_decode::<
6654            RunnerCallFlexibleTwoWayFieldsErrRequest,
6655            NonEmptyResultWithErrorClassification,
6656        >(
6657            (target,),
6658            0x7ae309383b07048e,
6659            fidl::encoding::DynamicFlags::empty(),
6660            _decode,
6661        )
6662    }
6663
6664    type ReceiveClosedEventsResponseFut =
6665        fidl::client::QueryResponseFut<(), fidl::encoding::DefaultFuchsiaResourceDialect>;
6666    fn r#receive_closed_events(
6667        &self,
6668        mut target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
6669        mut reporter: fidl::endpoints::ClientEnd<ClosedTargetEventReporterMarker>,
6670    ) -> Self::ReceiveClosedEventsResponseFut {
6671        fn _decode(
6672            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6673        ) -> Result<(), fidl::Error> {
6674            let _response = fidl::client::decode_transaction_body::<
6675                fidl::encoding::EmptyPayload,
6676                fidl::encoding::DefaultFuchsiaResourceDialect,
6677                0x48da834910571aeb,
6678            >(_buf?)?;
6679            Ok(_response)
6680        }
6681        self.client.send_query_and_decode::<RunnerReceiveClosedEventsRequest, ()>(
6682            (target, reporter),
6683            0x48da834910571aeb,
6684            fidl::encoding::DynamicFlags::empty(),
6685            _decode,
6686        )
6687    }
6688
6689    type ReceiveAjarEventsResponseFut =
6690        fidl::client::QueryResponseFut<(), fidl::encoding::DefaultFuchsiaResourceDialect>;
6691    fn r#receive_ajar_events(
6692        &self,
6693        mut target: fidl::endpoints::ClientEnd<AjarTargetMarker>,
6694        mut reporter: fidl::endpoints::ClientEnd<AjarTargetEventReporterMarker>,
6695    ) -> Self::ReceiveAjarEventsResponseFut {
6696        fn _decode(
6697            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6698        ) -> Result<(), fidl::Error> {
6699            let _response = fidl::client::decode_transaction_body::<
6700                fidl::encoding::EmptyPayload,
6701                fidl::encoding::DefaultFuchsiaResourceDialect,
6702                0xc5662b9a9c007a3,
6703            >(_buf?)?;
6704            Ok(_response)
6705        }
6706        self.client.send_query_and_decode::<RunnerReceiveAjarEventsRequest, ()>(
6707            (target, reporter),
6708            0xc5662b9a9c007a3,
6709            fidl::encoding::DynamicFlags::empty(),
6710            _decode,
6711        )
6712    }
6713
6714    type ReceiveOpenEventsResponseFut =
6715        fidl::client::QueryResponseFut<(), fidl::encoding::DefaultFuchsiaResourceDialect>;
6716    fn r#receive_open_events(
6717        &self,
6718        mut target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
6719        mut reporter: fidl::endpoints::ClientEnd<OpenTargetEventReporterMarker>,
6720    ) -> Self::ReceiveOpenEventsResponseFut {
6721        fn _decode(
6722            mut _buf: Result<<fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc, fidl::Error>,
6723        ) -> Result<(), fidl::Error> {
6724            let _response = fidl::client::decode_transaction_body::<
6725                fidl::encoding::EmptyPayload,
6726                fidl::encoding::DefaultFuchsiaResourceDialect,
6727                0x79a7073fd18edbdf,
6728            >(_buf?)?;
6729            Ok(_response)
6730        }
6731        self.client.send_query_and_decode::<RunnerReceiveOpenEventsRequest, ()>(
6732            (target, reporter),
6733            0x79a7073fd18edbdf,
6734            fidl::encoding::DynamicFlags::empty(),
6735            _decode,
6736        )
6737    }
6738}
6739
6740pub struct RunnerEventStream {
6741    event_receiver: fidl::client::EventReceiver<fidl::encoding::DefaultFuchsiaResourceDialect>,
6742}
6743
6744impl std::marker::Unpin for RunnerEventStream {}
6745
6746impl futures::stream::FusedStream for RunnerEventStream {
6747    fn is_terminated(&self) -> bool {
6748        self.event_receiver.is_terminated()
6749    }
6750}
6751
6752impl futures::Stream for RunnerEventStream {
6753    type Item = Result<RunnerEvent, fidl::Error>;
6754
6755    fn poll_next(
6756        mut self: std::pin::Pin<&mut Self>,
6757        cx: &mut std::task::Context<'_>,
6758    ) -> std::task::Poll<Option<Self::Item>> {
6759        match futures::ready!(futures::stream::StreamExt::poll_next_unpin(
6760            &mut self.event_receiver,
6761            cx
6762        )?) {
6763            Some(buf) => std::task::Poll::Ready(Some(RunnerEvent::decode(buf))),
6764            None => std::task::Poll::Ready(None),
6765        }
6766    }
6767}
6768
6769#[derive(Debug)]
6770pub enum RunnerEvent {}
6771
6772impl RunnerEvent {
6773    /// Decodes a message buffer as a [`RunnerEvent`].
6774    fn decode(
6775        mut buf: <fidl::encoding::DefaultFuchsiaResourceDialect as fidl::encoding::ResourceDialect>::MessageBufEtc,
6776    ) -> Result<RunnerEvent, fidl::Error> {
6777        let (bytes, _handles) = buf.split_mut();
6778        let (tx_header, _body_bytes) = fidl::encoding::decode_transaction_header(bytes)?;
6779        debug_assert_eq!(tx_header.tx_id, 0);
6780        match tx_header.ordinal {
6781            _ => Err(fidl::Error::UnknownOrdinal {
6782                ordinal: tx_header.ordinal,
6783                protocol_name: <RunnerMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME,
6784            }),
6785        }
6786    }
6787}
6788
6789/// A Stream of incoming requests for fidl.clientsuite/Runner.
6790pub struct RunnerRequestStream {
6791    inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
6792    is_terminated: bool,
6793}
6794
6795impl std::marker::Unpin for RunnerRequestStream {}
6796
6797impl futures::stream::FusedStream for RunnerRequestStream {
6798    fn is_terminated(&self) -> bool {
6799        self.is_terminated
6800    }
6801}
6802
6803impl fidl::endpoints::RequestStream for RunnerRequestStream {
6804    type Protocol = RunnerMarker;
6805    type ControlHandle = RunnerControlHandle;
6806
6807    fn from_channel(channel: ::fidl::AsyncChannel) -> Self {
6808        Self { inner: std::sync::Arc::new(fidl::ServeInner::new(channel)), is_terminated: false }
6809    }
6810
6811    fn control_handle(&self) -> Self::ControlHandle {
6812        RunnerControlHandle { inner: self.inner.clone() }
6813    }
6814
6815    fn into_inner(
6816        self,
6817    ) -> (::std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>, bool)
6818    {
6819        (self.inner, self.is_terminated)
6820    }
6821
6822    fn from_inner(
6823        inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
6824        is_terminated: bool,
6825    ) -> Self {
6826        Self { inner, is_terminated }
6827    }
6828}
6829
6830impl futures::Stream for RunnerRequestStream {
6831    type Item = Result<RunnerRequest, fidl::Error>;
6832
6833    fn poll_next(
6834        mut self: std::pin::Pin<&mut Self>,
6835        cx: &mut std::task::Context<'_>,
6836    ) -> std::task::Poll<Option<Self::Item>> {
6837        let this = &mut *self;
6838        if this.inner.check_shutdown(cx) {
6839            this.is_terminated = true;
6840            return std::task::Poll::Ready(None);
6841        }
6842        if this.is_terminated {
6843            panic!("polled RunnerRequestStream after completion");
6844        }
6845        fidl::encoding::with_tls_decode_buf::<_, fidl::encoding::DefaultFuchsiaResourceDialect>(
6846            |bytes, handles| {
6847                match this.inner.channel().read_etc(cx, bytes, handles) {
6848                    std::task::Poll::Ready(Ok(())) => {}
6849                    std::task::Poll::Pending => return std::task::Poll::Pending,
6850                    std::task::Poll::Ready(Err(zx_status::Status::PEER_CLOSED)) => {
6851                        this.is_terminated = true;
6852                        return std::task::Poll::Ready(None);
6853                    }
6854                    std::task::Poll::Ready(Err(e)) => {
6855                        return std::task::Poll::Ready(Some(Err(fidl::Error::ServerRequestRead(
6856                            e.into(),
6857                        ))))
6858                    }
6859                }
6860
6861                // A message has been received from the channel
6862                let (header, _body_bytes) = fidl::encoding::decode_transaction_header(bytes)?;
6863
6864                std::task::Poll::Ready(Some(match header.ordinal {
6865                    0x555d1430b913cdd4 => {
6866                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
6867                        let mut req = fidl::new_empty!(
6868                            fidl::encoding::EmptyPayload,
6869                            fidl::encoding::DefaultFuchsiaResourceDialect
6870                        );
6871                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&header, _body_bytes, handles, &mut req)?;
6872                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
6873                        Ok(RunnerRequest::GetVersion {
6874                            responder: RunnerGetVersionResponder {
6875                                control_handle: std::mem::ManuallyDrop::new(control_handle),
6876                                tx_id: header.tx_id,
6877                            },
6878                        })
6879                    }
6880                    0x755bc493368d7c50 => {
6881                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
6882                        let mut req = fidl::new_empty!(
6883                            RunnerIsTestEnabledRequest,
6884                            fidl::encoding::DefaultFuchsiaResourceDialect
6885                        );
6886                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerIsTestEnabledRequest>(&header, _body_bytes, handles, &mut req)?;
6887                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
6888                        Ok(RunnerRequest::IsTestEnabled {
6889                            test: req.test,
6890
6891                            responder: RunnerIsTestEnabledResponder {
6892                                control_handle: std::mem::ManuallyDrop::new(control_handle),
6893                                tx_id: header.tx_id,
6894                            },
6895                        })
6896                    }
6897                    0x5a77b04abdfde130 => {
6898                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
6899                        let mut req = fidl::new_empty!(
6900                            fidl::encoding::EmptyPayload,
6901                            fidl::encoding::DefaultFuchsiaResourceDialect
6902                        );
6903                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&header, _body_bytes, handles, &mut req)?;
6904                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
6905                        Ok(RunnerRequest::CheckAlive {
6906                            responder: RunnerCheckAliveResponder {
6907                                control_handle: std::mem::ManuallyDrop::new(control_handle),
6908                                tx_id: header.tx_id,
6909                            },
6910                        })
6911                    }
6912                    0x76b5610bfd4fa636 => {
6913                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
6914                        let mut req = fidl::new_empty!(
6915                            fidl::encoding::EmptyPayload,
6916                            fidl::encoding::DefaultFuchsiaResourceDialect
6917                        );
6918                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<fidl::encoding::EmptyPayload>(&header, _body_bytes, handles, &mut req)?;
6919                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
6920                        Ok(RunnerRequest::GetBindingsProperties {
6921                            responder: RunnerGetBindingsPropertiesResponder {
6922                                control_handle: std::mem::ManuallyDrop::new(control_handle),
6923                                tx_id: header.tx_id,
6924                            },
6925                        })
6926                    }
6927                    0x53ac710c20b320a1 => {
6928                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
6929                        let mut req = fidl::new_empty!(
6930                            RunnerCallTwoWayNoPayloadRequest,
6931                            fidl::encoding::DefaultFuchsiaResourceDialect
6932                        );
6933                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallTwoWayNoPayloadRequest>(&header, _body_bytes, handles, &mut req)?;
6934                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
6935                        Ok(RunnerRequest::CallTwoWayNoPayload {
6936                            target: req.target,
6937
6938                            responder: RunnerCallTwoWayNoPayloadResponder {
6939                                control_handle: std::mem::ManuallyDrop::new(control_handle),
6940                                tx_id: header.tx_id,
6941                            },
6942                        })
6943                    }
6944                    0x24e98c668499b946 => {
6945                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
6946                        let mut req = fidl::new_empty!(
6947                            RunnerCallTwoWayStructPayloadRequest,
6948                            fidl::encoding::DefaultFuchsiaResourceDialect
6949                        );
6950                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallTwoWayStructPayloadRequest>(&header, _body_bytes, handles, &mut req)?;
6951                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
6952                        Ok(RunnerRequest::CallTwoWayStructPayload {
6953                            target: req.target,
6954
6955                            responder: RunnerCallTwoWayStructPayloadResponder {
6956                                control_handle: std::mem::ManuallyDrop::new(control_handle),
6957                                tx_id: header.tx_id,
6958                            },
6959                        })
6960                    }
6961                    0x72e428e1605b76a => {
6962                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
6963                        let mut req = fidl::new_empty!(
6964                            RunnerCallTwoWayTablePayloadRequest,
6965                            fidl::encoding::DefaultFuchsiaResourceDialect
6966                        );
6967                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallTwoWayTablePayloadRequest>(&header, _body_bytes, handles, &mut req)?;
6968                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
6969                        Ok(RunnerRequest::CallTwoWayTablePayload {
6970                            target: req.target,
6971
6972                            responder: RunnerCallTwoWayTablePayloadResponder {
6973                                control_handle: std::mem::ManuallyDrop::new(control_handle),
6974                                tx_id: header.tx_id,
6975                            },
6976                        })
6977                    }
6978                    0x7dc9d67218343860 => {
6979                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
6980                        let mut req = fidl::new_empty!(
6981                            RunnerCallTwoWayUnionPayloadRequest,
6982                            fidl::encoding::DefaultFuchsiaResourceDialect
6983                        );
6984                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallTwoWayUnionPayloadRequest>(&header, _body_bytes, handles, &mut req)?;
6985                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
6986                        Ok(RunnerRequest::CallTwoWayUnionPayload {
6987                            target: req.target,
6988
6989                            responder: RunnerCallTwoWayUnionPayloadResponder {
6990                                control_handle: std::mem::ManuallyDrop::new(control_handle),
6991                                tx_id: header.tx_id,
6992                            },
6993                        })
6994                    }
6995                    0x2b07a57942c5f6e5 => {
6996                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
6997                        let mut req = fidl::new_empty!(
6998                            RunnerCallTwoWayStructPayloadErrRequest,
6999                            fidl::encoding::DefaultFuchsiaResourceDialect
7000                        );
7001                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallTwoWayStructPayloadErrRequest>(&header, _body_bytes, handles, &mut req)?;
7002                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
7003                        Ok(RunnerRequest::CallTwoWayStructPayloadErr {
7004                            target: req.target,
7005
7006                            responder: RunnerCallTwoWayStructPayloadErrResponder {
7007                                control_handle: std::mem::ManuallyDrop::new(control_handle),
7008                                tx_id: header.tx_id,
7009                            },
7010                        })
7011                    }
7012                    0x7c00a6ba2e6c9b45 => {
7013                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
7014                        let mut req = fidl::new_empty!(
7015                            RunnerCallTwoWayStructRequestRequest,
7016                            fidl::encoding::DefaultFuchsiaResourceDialect
7017                        );
7018                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallTwoWayStructRequestRequest>(&header, _body_bytes, handles, &mut req)?;
7019                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
7020                        Ok(RunnerRequest::CallTwoWayStructRequest {
7021                            target: req.target,
7022                            request: req.request,
7023
7024                            responder: RunnerCallTwoWayStructRequestResponder {
7025                                control_handle: std::mem::ManuallyDrop::new(control_handle),
7026                                tx_id: header.tx_id,
7027                            },
7028                        })
7029                    }
7030                    0x641763237d3885be => {
7031                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
7032                        let mut req = fidl::new_empty!(
7033                            RunnerCallTwoWayTableRequestRequest,
7034                            fidl::encoding::DefaultFuchsiaResourceDialect
7035                        );
7036                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallTwoWayTableRequestRequest>(&header, _body_bytes, handles, &mut req)?;
7037                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
7038                        Ok(RunnerRequest::CallTwoWayTableRequest {
7039                            target: req.target,
7040                            request: req.request,
7041
7042                            responder: RunnerCallTwoWayTableRequestResponder {
7043                                control_handle: std::mem::ManuallyDrop::new(control_handle),
7044                                tx_id: header.tx_id,
7045                            },
7046                        })
7047                    }
7048                    0x4be5f061df42619e => {
7049                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
7050                        let mut req = fidl::new_empty!(
7051                            RunnerCallTwoWayUnionRequestRequest,
7052                            fidl::encoding::DefaultFuchsiaResourceDialect
7053                        );
7054                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallTwoWayUnionRequestRequest>(&header, _body_bytes, handles, &mut req)?;
7055                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
7056                        Ok(RunnerRequest::CallTwoWayUnionRequest {
7057                            target: req.target,
7058                            request: req.request,
7059
7060                            responder: RunnerCallTwoWayUnionRequestResponder {
7061                                control_handle: std::mem::ManuallyDrop::new(control_handle),
7062                                tx_id: header.tx_id,
7063                            },
7064                        })
7065                    }
7066                    0x24b6eea8cbdccc09 => {
7067                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
7068                        let mut req = fidl::new_empty!(
7069                            RunnerCallOneWayNoRequestRequest,
7070                            fidl::encoding::DefaultFuchsiaResourceDialect
7071                        );
7072                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallOneWayNoRequestRequest>(&header, _body_bytes, handles, &mut req)?;
7073                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
7074                        Ok(RunnerRequest::CallOneWayNoRequest {
7075                            target: req.target,
7076
7077                            responder: RunnerCallOneWayNoRequestResponder {
7078                                control_handle: std::mem::ManuallyDrop::new(control_handle),
7079                                tx_id: header.tx_id,
7080                            },
7081                        })
7082                    }
7083                    0x352a2907a0fcb420 => {
7084                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
7085                        let mut req = fidl::new_empty!(
7086                            RunnerCallOneWayStructRequestRequest,
7087                            fidl::encoding::DefaultFuchsiaResourceDialect
7088                        );
7089                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallOneWayStructRequestRequest>(&header, _body_bytes, handles, &mut req)?;
7090                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
7091                        Ok(RunnerRequest::CallOneWayStructRequest {
7092                            target: req.target,
7093                            request: req.request,
7094
7095                            responder: RunnerCallOneWayStructRequestResponder {
7096                                control_handle: std::mem::ManuallyDrop::new(control_handle),
7097                                tx_id: header.tx_id,
7098                            },
7099                        })
7100                    }
7101                    0x734121bf8bf336ef => {
7102                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
7103                        let mut req = fidl::new_empty!(
7104                            RunnerCallOneWayTableRequestRequest,
7105                            fidl::encoding::DefaultFuchsiaResourceDialect
7106                        );
7107                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallOneWayTableRequestRequest>(&header, _body_bytes, handles, &mut req)?;
7108                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
7109                        Ok(RunnerRequest::CallOneWayTableRequest {
7110                            target: req.target,
7111                            request: req.request,
7112
7113                            responder: RunnerCallOneWayTableRequestResponder {
7114                                control_handle: std::mem::ManuallyDrop::new(control_handle),
7115                                tx_id: header.tx_id,
7116                            },
7117                        })
7118                    }
7119                    0x9be8e5eb7d50eb6 => {
7120                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
7121                        let mut req = fidl::new_empty!(
7122                            RunnerCallOneWayUnionRequestRequest,
7123                            fidl::encoding::DefaultFuchsiaResourceDialect
7124                        );
7125                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallOneWayUnionRequestRequest>(&header, _body_bytes, handles, &mut req)?;
7126                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
7127                        Ok(RunnerRequest::CallOneWayUnionRequest {
7128                            target: req.target,
7129                            request: req.request,
7130
7131                            responder: RunnerCallOneWayUnionRequestResponder {
7132                                control_handle: std::mem::ManuallyDrop::new(control_handle),
7133                                tx_id: header.tx_id,
7134                            },
7135                        })
7136                    }
7137                    0x4edd0b6f52c0446b => {
7138                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
7139                        let mut req = fidl::new_empty!(
7140                            RunnerCallStrictOneWayRequest,
7141                            fidl::encoding::DefaultFuchsiaResourceDialect
7142                        );
7143                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallStrictOneWayRequest>(&header, _body_bytes, handles, &mut req)?;
7144                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
7145                        Ok(RunnerRequest::CallStrictOneWay {
7146                            target: req.target,
7147
7148                            responder: RunnerCallStrictOneWayResponder {
7149                                control_handle: std::mem::ManuallyDrop::new(control_handle),
7150                                tx_id: header.tx_id,
7151                            },
7152                        })
7153                    }
7154                    0x7253f10a77dfe817 => {
7155                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
7156                        let mut req = fidl::new_empty!(
7157                            RunnerCallFlexibleOneWayRequest,
7158                            fidl::encoding::DefaultFuchsiaResourceDialect
7159                        );
7160                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallFlexibleOneWayRequest>(&header, _body_bytes, handles, &mut req)?;
7161                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
7162                        Ok(RunnerRequest::CallFlexibleOneWay {
7163                            target: req.target,
7164
7165                            responder: RunnerCallFlexibleOneWayResponder {
7166                                control_handle: std::mem::ManuallyDrop::new(control_handle),
7167                                tx_id: header.tx_id,
7168                            },
7169                        })
7170                    }
7171                    0x1fa9fb7414aedd27 => {
7172                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
7173                        let mut req = fidl::new_empty!(
7174                            RunnerCallStrictTwoWayRequest,
7175                            fidl::encoding::DefaultFuchsiaResourceDialect
7176                        );
7177                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallStrictTwoWayRequest>(&header, _body_bytes, handles, &mut req)?;
7178                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
7179                        Ok(RunnerRequest::CallStrictTwoWay {
7180                            target: req.target,
7181
7182                            responder: RunnerCallStrictTwoWayResponder {
7183                                control_handle: std::mem::ManuallyDrop::new(control_handle),
7184                                tx_id: header.tx_id,
7185                            },
7186                        })
7187                    }
7188                    0x6f690e00ebf6f123 => {
7189                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
7190                        let mut req = fidl::new_empty!(
7191                            RunnerCallStrictTwoWayFieldsRequest,
7192                            fidl::encoding::DefaultFuchsiaResourceDialect
7193                        );
7194                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallStrictTwoWayFieldsRequest>(&header, _body_bytes, handles, &mut req)?;
7195                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
7196                        Ok(RunnerRequest::CallStrictTwoWayFields {
7197                            target: req.target,
7198
7199                            responder: RunnerCallStrictTwoWayFieldsResponder {
7200                                control_handle: std::mem::ManuallyDrop::new(control_handle),
7201                                tx_id: header.tx_id,
7202                            },
7203                        })
7204                    }
7205                    0x51d6bc7cf6cbaf1a => {
7206                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
7207                        let mut req = fidl::new_empty!(
7208                            RunnerCallStrictTwoWayErrRequest,
7209                            fidl::encoding::DefaultFuchsiaResourceDialect
7210                        );
7211                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallStrictTwoWayErrRequest>(&header, _body_bytes, handles, &mut req)?;
7212                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
7213                        Ok(RunnerRequest::CallStrictTwoWayErr {
7214                            target: req.target,
7215
7216                            responder: RunnerCallStrictTwoWayErrResponder {
7217                                control_handle: std::mem::ManuallyDrop::new(control_handle),
7218                                tx_id: header.tx_id,
7219                            },
7220                        })
7221                    }
7222                    0x6fa31ced05074c05 => {
7223                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
7224                        let mut req = fidl::new_empty!(
7225                            RunnerCallStrictTwoWayFieldsErrRequest,
7226                            fidl::encoding::DefaultFuchsiaResourceDialect
7227                        );
7228                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallStrictTwoWayFieldsErrRequest>(&header, _body_bytes, handles, &mut req)?;
7229                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
7230                        Ok(RunnerRequest::CallStrictTwoWayFieldsErr {
7231                            target: req.target,
7232
7233                            responder: RunnerCallStrictTwoWayFieldsErrResponder {
7234                                control_handle: std::mem::ManuallyDrop::new(control_handle),
7235                                tx_id: header.tx_id,
7236                            },
7237                        })
7238                    }
7239                    0x411f70724876d49 => {
7240                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
7241                        let mut req = fidl::new_empty!(
7242                            RunnerCallFlexibleTwoWayRequest,
7243                            fidl::encoding::DefaultFuchsiaResourceDialect
7244                        );
7245                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallFlexibleTwoWayRequest>(&header, _body_bytes, handles, &mut req)?;
7246                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
7247                        Ok(RunnerRequest::CallFlexibleTwoWay {
7248                            target: req.target,
7249
7250                            responder: RunnerCallFlexibleTwoWayResponder {
7251                                control_handle: std::mem::ManuallyDrop::new(control_handle),
7252                                tx_id: header.tx_id,
7253                            },
7254                        })
7255                    }
7256                    0x330996b623598eed => {
7257                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
7258                        let mut req = fidl::new_empty!(
7259                            RunnerCallFlexibleTwoWayFieldsRequest,
7260                            fidl::encoding::DefaultFuchsiaResourceDialect
7261                        );
7262                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallFlexibleTwoWayFieldsRequest>(&header, _body_bytes, handles, &mut req)?;
7263                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
7264                        Ok(RunnerRequest::CallFlexibleTwoWayFields {
7265                            target: req.target,
7266
7267                            responder: RunnerCallFlexibleTwoWayFieldsResponder {
7268                                control_handle: std::mem::ManuallyDrop::new(control_handle),
7269                                tx_id: header.tx_id,
7270                            },
7271                        })
7272                    }
7273                    0x5ddbf88a353a2a57 => {
7274                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
7275                        let mut req = fidl::new_empty!(
7276                            RunnerCallFlexibleTwoWayErrRequest,
7277                            fidl::encoding::DefaultFuchsiaResourceDialect
7278                        );
7279                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallFlexibleTwoWayErrRequest>(&header, _body_bytes, handles, &mut req)?;
7280                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
7281                        Ok(RunnerRequest::CallFlexibleTwoWayErr {
7282                            target: req.target,
7283
7284                            responder: RunnerCallFlexibleTwoWayErrResponder {
7285                                control_handle: std::mem::ManuallyDrop::new(control_handle),
7286                                tx_id: header.tx_id,
7287                            },
7288                        })
7289                    }
7290                    0x7ae309383b07048e => {
7291                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
7292                        let mut req = fidl::new_empty!(
7293                            RunnerCallFlexibleTwoWayFieldsErrRequest,
7294                            fidl::encoding::DefaultFuchsiaResourceDialect
7295                        );
7296                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerCallFlexibleTwoWayFieldsErrRequest>(&header, _body_bytes, handles, &mut req)?;
7297                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
7298                        Ok(RunnerRequest::CallFlexibleTwoWayFieldsErr {
7299                            target: req.target,
7300
7301                            responder: RunnerCallFlexibleTwoWayFieldsErrResponder {
7302                                control_handle: std::mem::ManuallyDrop::new(control_handle),
7303                                tx_id: header.tx_id,
7304                            },
7305                        })
7306                    }
7307                    0x48da834910571aeb => {
7308                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
7309                        let mut req = fidl::new_empty!(
7310                            RunnerReceiveClosedEventsRequest,
7311                            fidl::encoding::DefaultFuchsiaResourceDialect
7312                        );
7313                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerReceiveClosedEventsRequest>(&header, _body_bytes, handles, &mut req)?;
7314                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
7315                        Ok(RunnerRequest::ReceiveClosedEvents {
7316                            target: req.target,
7317                            reporter: req.reporter,
7318
7319                            responder: RunnerReceiveClosedEventsResponder {
7320                                control_handle: std::mem::ManuallyDrop::new(control_handle),
7321                                tx_id: header.tx_id,
7322                            },
7323                        })
7324                    }
7325                    0xc5662b9a9c007a3 => {
7326                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
7327                        let mut req = fidl::new_empty!(
7328                            RunnerReceiveAjarEventsRequest,
7329                            fidl::encoding::DefaultFuchsiaResourceDialect
7330                        );
7331                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerReceiveAjarEventsRequest>(&header, _body_bytes, handles, &mut req)?;
7332                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
7333                        Ok(RunnerRequest::ReceiveAjarEvents {
7334                            target: req.target,
7335                            reporter: req.reporter,
7336
7337                            responder: RunnerReceiveAjarEventsResponder {
7338                                control_handle: std::mem::ManuallyDrop::new(control_handle),
7339                                tx_id: header.tx_id,
7340                            },
7341                        })
7342                    }
7343                    0x79a7073fd18edbdf => {
7344                        header.validate_request_tx_id(fidl::MethodType::TwoWay)?;
7345                        let mut req = fidl::new_empty!(
7346                            RunnerReceiveOpenEventsRequest,
7347                            fidl::encoding::DefaultFuchsiaResourceDialect
7348                        );
7349                        fidl::encoding::Decoder::<fidl::encoding::DefaultFuchsiaResourceDialect>::decode_into::<RunnerReceiveOpenEventsRequest>(&header, _body_bytes, handles, &mut req)?;
7350                        let control_handle = RunnerControlHandle { inner: this.inner.clone() };
7351                        Ok(RunnerRequest::ReceiveOpenEvents {
7352                            target: req.target,
7353                            reporter: req.reporter,
7354
7355                            responder: RunnerReceiveOpenEventsResponder {
7356                                control_handle: std::mem::ManuallyDrop::new(control_handle),
7357                                tx_id: header.tx_id,
7358                            },
7359                        })
7360                    }
7361                    _ => Err(fidl::Error::UnknownOrdinal {
7362                        ordinal: header.ordinal,
7363                        protocol_name:
7364                            <RunnerMarker as fidl::endpoints::ProtocolMarker>::DEBUG_NAME,
7365                    }),
7366                }))
7367            },
7368        )
7369    }
7370}
7371
7372#[derive(Debug)]
7373pub enum RunnerRequest {
7374    GetVersion {
7375        responder: RunnerGetVersionResponder,
7376    },
7377    IsTestEnabled {
7378        test: Test,
7379        responder: RunnerIsTestEnabledResponder,
7380    },
7381    CheckAlive {
7382        responder: RunnerCheckAliveResponder,
7383    },
7384    GetBindingsProperties {
7385        responder: RunnerGetBindingsPropertiesResponder,
7386    },
7387    CallTwoWayNoPayload {
7388        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7389        responder: RunnerCallTwoWayNoPayloadResponder,
7390    },
7391    CallTwoWayStructPayload {
7392        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7393        responder: RunnerCallTwoWayStructPayloadResponder,
7394    },
7395    CallTwoWayTablePayload {
7396        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7397        responder: RunnerCallTwoWayTablePayloadResponder,
7398    },
7399    CallTwoWayUnionPayload {
7400        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7401        responder: RunnerCallTwoWayUnionPayloadResponder,
7402    },
7403    CallTwoWayStructPayloadErr {
7404        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7405        responder: RunnerCallTwoWayStructPayloadErrResponder,
7406    },
7407    CallTwoWayStructRequest {
7408        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7409        request: NonEmptyPayload,
7410        responder: RunnerCallTwoWayStructRequestResponder,
7411    },
7412    CallTwoWayTableRequest {
7413        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7414        request: TablePayload,
7415        responder: RunnerCallTwoWayTableRequestResponder,
7416    },
7417    CallTwoWayUnionRequest {
7418        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7419        request: UnionPayload,
7420        responder: RunnerCallTwoWayUnionRequestResponder,
7421    },
7422    CallOneWayNoRequest {
7423        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7424        responder: RunnerCallOneWayNoRequestResponder,
7425    },
7426    CallOneWayStructRequest {
7427        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7428        request: NonEmptyPayload,
7429        responder: RunnerCallOneWayStructRequestResponder,
7430    },
7431    CallOneWayTableRequest {
7432        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7433        request: TablePayload,
7434        responder: RunnerCallOneWayTableRequestResponder,
7435    },
7436    CallOneWayUnionRequest {
7437        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7438        request: UnionPayload,
7439        responder: RunnerCallOneWayUnionRequestResponder,
7440    },
7441    CallStrictOneWay {
7442        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
7443        responder: RunnerCallStrictOneWayResponder,
7444    },
7445    CallFlexibleOneWay {
7446        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
7447        responder: RunnerCallFlexibleOneWayResponder,
7448    },
7449    CallStrictTwoWay {
7450        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
7451        responder: RunnerCallStrictTwoWayResponder,
7452    },
7453    CallStrictTwoWayFields {
7454        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
7455        responder: RunnerCallStrictTwoWayFieldsResponder,
7456    },
7457    CallStrictTwoWayErr {
7458        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
7459        responder: RunnerCallStrictTwoWayErrResponder,
7460    },
7461    CallStrictTwoWayFieldsErr {
7462        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
7463        responder: RunnerCallStrictTwoWayFieldsErrResponder,
7464    },
7465    CallFlexibleTwoWay {
7466        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
7467        responder: RunnerCallFlexibleTwoWayResponder,
7468    },
7469    CallFlexibleTwoWayFields {
7470        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
7471        responder: RunnerCallFlexibleTwoWayFieldsResponder,
7472    },
7473    CallFlexibleTwoWayErr {
7474        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
7475        responder: RunnerCallFlexibleTwoWayErrResponder,
7476    },
7477    CallFlexibleTwoWayFieldsErr {
7478        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
7479        responder: RunnerCallFlexibleTwoWayFieldsErrResponder,
7480    },
7481    ReceiveClosedEvents {
7482        target: fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7483        reporter: fidl::endpoints::ClientEnd<ClosedTargetEventReporterMarker>,
7484        responder: RunnerReceiveClosedEventsResponder,
7485    },
7486    ReceiveAjarEvents {
7487        target: fidl::endpoints::ClientEnd<AjarTargetMarker>,
7488        reporter: fidl::endpoints::ClientEnd<AjarTargetEventReporterMarker>,
7489        responder: RunnerReceiveAjarEventsResponder,
7490    },
7491    ReceiveOpenEvents {
7492        target: fidl::endpoints::ClientEnd<OpenTargetMarker>,
7493        reporter: fidl::endpoints::ClientEnd<OpenTargetEventReporterMarker>,
7494        responder: RunnerReceiveOpenEventsResponder,
7495    },
7496}
7497
7498impl RunnerRequest {
7499    #[allow(irrefutable_let_patterns)]
7500    pub fn into_get_version(self) -> Option<(RunnerGetVersionResponder)> {
7501        if let RunnerRequest::GetVersion { responder } = self {
7502            Some((responder))
7503        } else {
7504            None
7505        }
7506    }
7507
7508    #[allow(irrefutable_let_patterns)]
7509    pub fn into_is_test_enabled(self) -> Option<(Test, RunnerIsTestEnabledResponder)> {
7510        if let RunnerRequest::IsTestEnabled { test, responder } = self {
7511            Some((test, responder))
7512        } else {
7513            None
7514        }
7515    }
7516
7517    #[allow(irrefutable_let_patterns)]
7518    pub fn into_check_alive(self) -> Option<(RunnerCheckAliveResponder)> {
7519        if let RunnerRequest::CheckAlive { responder } = self {
7520            Some((responder))
7521        } else {
7522            None
7523        }
7524    }
7525
7526    #[allow(irrefutable_let_patterns)]
7527    pub fn into_get_bindings_properties(self) -> Option<(RunnerGetBindingsPropertiesResponder)> {
7528        if let RunnerRequest::GetBindingsProperties { responder } = self {
7529            Some((responder))
7530        } else {
7531            None
7532        }
7533    }
7534
7535    #[allow(irrefutable_let_patterns)]
7536    pub fn into_call_two_way_no_payload(
7537        self,
7538    ) -> Option<(fidl::endpoints::ClientEnd<ClosedTargetMarker>, RunnerCallTwoWayNoPayloadResponder)>
7539    {
7540        if let RunnerRequest::CallTwoWayNoPayload { target, responder } = self {
7541            Some((target, responder))
7542        } else {
7543            None
7544        }
7545    }
7546
7547    #[allow(irrefutable_let_patterns)]
7548    pub fn into_call_two_way_struct_payload(
7549        self,
7550    ) -> Option<(
7551        fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7552        RunnerCallTwoWayStructPayloadResponder,
7553    )> {
7554        if let RunnerRequest::CallTwoWayStructPayload { target, responder } = self {
7555            Some((target, responder))
7556        } else {
7557            None
7558        }
7559    }
7560
7561    #[allow(irrefutable_let_patterns)]
7562    pub fn into_call_two_way_table_payload(
7563        self,
7564    ) -> Option<(
7565        fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7566        RunnerCallTwoWayTablePayloadResponder,
7567    )> {
7568        if let RunnerRequest::CallTwoWayTablePayload { target, responder } = self {
7569            Some((target, responder))
7570        } else {
7571            None
7572        }
7573    }
7574
7575    #[allow(irrefutable_let_patterns)]
7576    pub fn into_call_two_way_union_payload(
7577        self,
7578    ) -> Option<(
7579        fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7580        RunnerCallTwoWayUnionPayloadResponder,
7581    )> {
7582        if let RunnerRequest::CallTwoWayUnionPayload { target, responder } = self {
7583            Some((target, responder))
7584        } else {
7585            None
7586        }
7587    }
7588
7589    #[allow(irrefutable_let_patterns)]
7590    pub fn into_call_two_way_struct_payload_err(
7591        self,
7592    ) -> Option<(
7593        fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7594        RunnerCallTwoWayStructPayloadErrResponder,
7595    )> {
7596        if let RunnerRequest::CallTwoWayStructPayloadErr { target, responder } = self {
7597            Some((target, responder))
7598        } else {
7599            None
7600        }
7601    }
7602
7603    #[allow(irrefutable_let_patterns)]
7604    pub fn into_call_two_way_struct_request(
7605        self,
7606    ) -> Option<(
7607        fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7608        NonEmptyPayload,
7609        RunnerCallTwoWayStructRequestResponder,
7610    )> {
7611        if let RunnerRequest::CallTwoWayStructRequest { target, request, responder } = self {
7612            Some((target, request, responder))
7613        } else {
7614            None
7615        }
7616    }
7617
7618    #[allow(irrefutable_let_patterns)]
7619    pub fn into_call_two_way_table_request(
7620        self,
7621    ) -> Option<(
7622        fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7623        TablePayload,
7624        RunnerCallTwoWayTableRequestResponder,
7625    )> {
7626        if let RunnerRequest::CallTwoWayTableRequest { target, request, responder } = self {
7627            Some((target, request, responder))
7628        } else {
7629            None
7630        }
7631    }
7632
7633    #[allow(irrefutable_let_patterns)]
7634    pub fn into_call_two_way_union_request(
7635        self,
7636    ) -> Option<(
7637        fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7638        UnionPayload,
7639        RunnerCallTwoWayUnionRequestResponder,
7640    )> {
7641        if let RunnerRequest::CallTwoWayUnionRequest { target, request, responder } = self {
7642            Some((target, request, responder))
7643        } else {
7644            None
7645        }
7646    }
7647
7648    #[allow(irrefutable_let_patterns)]
7649    pub fn into_call_one_way_no_request(
7650        self,
7651    ) -> Option<(fidl::endpoints::ClientEnd<ClosedTargetMarker>, RunnerCallOneWayNoRequestResponder)>
7652    {
7653        if let RunnerRequest::CallOneWayNoRequest { target, responder } = self {
7654            Some((target, responder))
7655        } else {
7656            None
7657        }
7658    }
7659
7660    #[allow(irrefutable_let_patterns)]
7661    pub fn into_call_one_way_struct_request(
7662        self,
7663    ) -> Option<(
7664        fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7665        NonEmptyPayload,
7666        RunnerCallOneWayStructRequestResponder,
7667    )> {
7668        if let RunnerRequest::CallOneWayStructRequest { target, request, responder } = self {
7669            Some((target, request, responder))
7670        } else {
7671            None
7672        }
7673    }
7674
7675    #[allow(irrefutable_let_patterns)]
7676    pub fn into_call_one_way_table_request(
7677        self,
7678    ) -> Option<(
7679        fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7680        TablePayload,
7681        RunnerCallOneWayTableRequestResponder,
7682    )> {
7683        if let RunnerRequest::CallOneWayTableRequest { target, request, responder } = self {
7684            Some((target, request, responder))
7685        } else {
7686            None
7687        }
7688    }
7689
7690    #[allow(irrefutable_let_patterns)]
7691    pub fn into_call_one_way_union_request(
7692        self,
7693    ) -> Option<(
7694        fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7695        UnionPayload,
7696        RunnerCallOneWayUnionRequestResponder,
7697    )> {
7698        if let RunnerRequest::CallOneWayUnionRequest { target, request, responder } = self {
7699            Some((target, request, responder))
7700        } else {
7701            None
7702        }
7703    }
7704
7705    #[allow(irrefutable_let_patterns)]
7706    pub fn into_call_strict_one_way(
7707        self,
7708    ) -> Option<(fidl::endpoints::ClientEnd<OpenTargetMarker>, RunnerCallStrictOneWayResponder)>
7709    {
7710        if let RunnerRequest::CallStrictOneWay { target, responder } = self {
7711            Some((target, responder))
7712        } else {
7713            None
7714        }
7715    }
7716
7717    #[allow(irrefutable_let_patterns)]
7718    pub fn into_call_flexible_one_way(
7719        self,
7720    ) -> Option<(fidl::endpoints::ClientEnd<OpenTargetMarker>, RunnerCallFlexibleOneWayResponder)>
7721    {
7722        if let RunnerRequest::CallFlexibleOneWay { target, responder } = self {
7723            Some((target, responder))
7724        } else {
7725            None
7726        }
7727    }
7728
7729    #[allow(irrefutable_let_patterns)]
7730    pub fn into_call_strict_two_way(
7731        self,
7732    ) -> Option<(fidl::endpoints::ClientEnd<OpenTargetMarker>, RunnerCallStrictTwoWayResponder)>
7733    {
7734        if let RunnerRequest::CallStrictTwoWay { target, responder } = self {
7735            Some((target, responder))
7736        } else {
7737            None
7738        }
7739    }
7740
7741    #[allow(irrefutable_let_patterns)]
7742    pub fn into_call_strict_two_way_fields(
7743        self,
7744    ) -> Option<(fidl::endpoints::ClientEnd<OpenTargetMarker>, RunnerCallStrictTwoWayFieldsResponder)>
7745    {
7746        if let RunnerRequest::CallStrictTwoWayFields { target, responder } = self {
7747            Some((target, responder))
7748        } else {
7749            None
7750        }
7751    }
7752
7753    #[allow(irrefutable_let_patterns)]
7754    pub fn into_call_strict_two_way_err(
7755        self,
7756    ) -> Option<(fidl::endpoints::ClientEnd<OpenTargetMarker>, RunnerCallStrictTwoWayErrResponder)>
7757    {
7758        if let RunnerRequest::CallStrictTwoWayErr { target, responder } = self {
7759            Some((target, responder))
7760        } else {
7761            None
7762        }
7763    }
7764
7765    #[allow(irrefutable_let_patterns)]
7766    pub fn into_call_strict_two_way_fields_err(
7767        self,
7768    ) -> Option<(
7769        fidl::endpoints::ClientEnd<OpenTargetMarker>,
7770        RunnerCallStrictTwoWayFieldsErrResponder,
7771    )> {
7772        if let RunnerRequest::CallStrictTwoWayFieldsErr { target, responder } = self {
7773            Some((target, responder))
7774        } else {
7775            None
7776        }
7777    }
7778
7779    #[allow(irrefutable_let_patterns)]
7780    pub fn into_call_flexible_two_way(
7781        self,
7782    ) -> Option<(fidl::endpoints::ClientEnd<OpenTargetMarker>, RunnerCallFlexibleTwoWayResponder)>
7783    {
7784        if let RunnerRequest::CallFlexibleTwoWay { target, responder } = self {
7785            Some((target, responder))
7786        } else {
7787            None
7788        }
7789    }
7790
7791    #[allow(irrefutable_let_patterns)]
7792    pub fn into_call_flexible_two_way_fields(
7793        self,
7794    ) -> Option<(
7795        fidl::endpoints::ClientEnd<OpenTargetMarker>,
7796        RunnerCallFlexibleTwoWayFieldsResponder,
7797    )> {
7798        if let RunnerRequest::CallFlexibleTwoWayFields { target, responder } = self {
7799            Some((target, responder))
7800        } else {
7801            None
7802        }
7803    }
7804
7805    #[allow(irrefutable_let_patterns)]
7806    pub fn into_call_flexible_two_way_err(
7807        self,
7808    ) -> Option<(fidl::endpoints::ClientEnd<OpenTargetMarker>, RunnerCallFlexibleTwoWayErrResponder)>
7809    {
7810        if let RunnerRequest::CallFlexibleTwoWayErr { target, responder } = self {
7811            Some((target, responder))
7812        } else {
7813            None
7814        }
7815    }
7816
7817    #[allow(irrefutable_let_patterns)]
7818    pub fn into_call_flexible_two_way_fields_err(
7819        self,
7820    ) -> Option<(
7821        fidl::endpoints::ClientEnd<OpenTargetMarker>,
7822        RunnerCallFlexibleTwoWayFieldsErrResponder,
7823    )> {
7824        if let RunnerRequest::CallFlexibleTwoWayFieldsErr { target, responder } = self {
7825            Some((target, responder))
7826        } else {
7827            None
7828        }
7829    }
7830
7831    #[allow(irrefutable_let_patterns)]
7832    pub fn into_receive_closed_events(
7833        self,
7834    ) -> Option<(
7835        fidl::endpoints::ClientEnd<ClosedTargetMarker>,
7836        fidl::endpoints::ClientEnd<ClosedTargetEventReporterMarker>,
7837        RunnerReceiveClosedEventsResponder,
7838    )> {
7839        if let RunnerRequest::ReceiveClosedEvents { target, reporter, responder } = self {
7840            Some((target, reporter, responder))
7841        } else {
7842            None
7843        }
7844    }
7845
7846    #[allow(irrefutable_let_patterns)]
7847    pub fn into_receive_ajar_events(
7848        self,
7849    ) -> Option<(
7850        fidl::endpoints::ClientEnd<AjarTargetMarker>,
7851        fidl::endpoints::ClientEnd<AjarTargetEventReporterMarker>,
7852        RunnerReceiveAjarEventsResponder,
7853    )> {
7854        if let RunnerRequest::ReceiveAjarEvents { target, reporter, responder } = self {
7855            Some((target, reporter, responder))
7856        } else {
7857            None
7858        }
7859    }
7860
7861    #[allow(irrefutable_let_patterns)]
7862    pub fn into_receive_open_events(
7863        self,
7864    ) -> Option<(
7865        fidl::endpoints::ClientEnd<OpenTargetMarker>,
7866        fidl::endpoints::ClientEnd<OpenTargetEventReporterMarker>,
7867        RunnerReceiveOpenEventsResponder,
7868    )> {
7869        if let RunnerRequest::ReceiveOpenEvents { target, reporter, responder } = self {
7870            Some((target, reporter, responder))
7871        } else {
7872            None
7873        }
7874    }
7875
7876    /// Name of the method defined in FIDL
7877    pub fn method_name(&self) -> &'static str {
7878        match *self {
7879            RunnerRequest::GetVersion { .. } => "get_version",
7880            RunnerRequest::IsTestEnabled { .. } => "is_test_enabled",
7881            RunnerRequest::CheckAlive { .. } => "check_alive",
7882            RunnerRequest::GetBindingsProperties { .. } => "get_bindings_properties",
7883            RunnerRequest::CallTwoWayNoPayload { .. } => "call_two_way_no_payload",
7884            RunnerRequest::CallTwoWayStructPayload { .. } => "call_two_way_struct_payload",
7885            RunnerRequest::CallTwoWayTablePayload { .. } => "call_two_way_table_payload",
7886            RunnerRequest::CallTwoWayUnionPayload { .. } => "call_two_way_union_payload",
7887            RunnerRequest::CallTwoWayStructPayloadErr { .. } => "call_two_way_struct_payload_err",
7888            RunnerRequest::CallTwoWayStructRequest { .. } => "call_two_way_struct_request",
7889            RunnerRequest::CallTwoWayTableRequest { .. } => "call_two_way_table_request",
7890            RunnerRequest::CallTwoWayUnionRequest { .. } => "call_two_way_union_request",
7891            RunnerRequest::CallOneWayNoRequest { .. } => "call_one_way_no_request",
7892            RunnerRequest::CallOneWayStructRequest { .. } => "call_one_way_struct_request",
7893            RunnerRequest::CallOneWayTableRequest { .. } => "call_one_way_table_request",
7894            RunnerRequest::CallOneWayUnionRequest { .. } => "call_one_way_union_request",
7895            RunnerRequest::CallStrictOneWay { .. } => "call_strict_one_way",
7896            RunnerRequest::CallFlexibleOneWay { .. } => "call_flexible_one_way",
7897            RunnerRequest::CallStrictTwoWay { .. } => "call_strict_two_way",
7898            RunnerRequest::CallStrictTwoWayFields { .. } => "call_strict_two_way_fields",
7899            RunnerRequest::CallStrictTwoWayErr { .. } => "call_strict_two_way_err",
7900            RunnerRequest::CallStrictTwoWayFieldsErr { .. } => "call_strict_two_way_fields_err",
7901            RunnerRequest::CallFlexibleTwoWay { .. } => "call_flexible_two_way",
7902            RunnerRequest::CallFlexibleTwoWayFields { .. } => "call_flexible_two_way_fields",
7903            RunnerRequest::CallFlexibleTwoWayErr { .. } => "call_flexible_two_way_err",
7904            RunnerRequest::CallFlexibleTwoWayFieldsErr { .. } => "call_flexible_two_way_fields_err",
7905            RunnerRequest::ReceiveClosedEvents { .. } => "receive_closed_events",
7906            RunnerRequest::ReceiveAjarEvents { .. } => "receive_ajar_events",
7907            RunnerRequest::ReceiveOpenEvents { .. } => "receive_open_events",
7908        }
7909    }
7910}
7911
7912#[derive(Debug, Clone)]
7913pub struct RunnerControlHandle {
7914    inner: std::sync::Arc<fidl::ServeInner<fidl::encoding::DefaultFuchsiaResourceDialect>>,
7915}
7916
7917impl fidl::endpoints::ControlHandle for RunnerControlHandle {
7918    fn shutdown(&self) {
7919        self.inner.shutdown()
7920    }
7921    fn shutdown_with_epitaph(&self, status: zx_status::Status) {
7922        self.inner.shutdown_with_epitaph(status)
7923    }
7924
7925    fn is_closed(&self) -> bool {
7926        self.inner.channel().is_closed()
7927    }
7928    fn on_closed(&self) -> fidl::OnSignalsRef<'_> {
7929        self.inner.channel().on_closed()
7930    }
7931
7932    #[cfg(target_os = "fuchsia")]
7933    fn signal_peer(
7934        &self,
7935        clear_mask: zx::Signals,
7936        set_mask: zx::Signals,
7937    ) -> Result<(), zx_status::Status> {
7938        use fidl::Peered;
7939        self.inner.channel().signal_peer(clear_mask, set_mask)
7940    }
7941}
7942
7943impl RunnerControlHandle {}
7944
7945#[must_use = "FIDL methods require a response to be sent"]
7946#[derive(Debug)]
7947pub struct RunnerGetVersionResponder {
7948    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
7949    tx_id: u32,
7950}
7951
7952/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
7953/// if the responder is dropped without sending a response, so that the client
7954/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
7955impl std::ops::Drop for RunnerGetVersionResponder {
7956    fn drop(&mut self) {
7957        self.control_handle.shutdown();
7958        // Safety: drops once, never accessed again
7959        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
7960    }
7961}
7962
7963impl fidl::endpoints::Responder for RunnerGetVersionResponder {
7964    type ControlHandle = RunnerControlHandle;
7965
7966    fn control_handle(&self) -> &RunnerControlHandle {
7967        &self.control_handle
7968    }
7969
7970    fn drop_without_shutdown(mut self) {
7971        // Safety: drops once, never accessed again due to mem::forget
7972        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
7973        // Prevent Drop from running (which would shut down the channel)
7974        std::mem::forget(self);
7975    }
7976}
7977
7978impl RunnerGetVersionResponder {
7979    /// Sends a response to the FIDL transaction.
7980    ///
7981    /// Sets the channel to shutdown if an error occurs.
7982    pub fn send(self, mut version: u64) -> Result<(), fidl::Error> {
7983        let _result = self.send_raw(version);
7984        if _result.is_err() {
7985            self.control_handle.shutdown();
7986        }
7987        self.drop_without_shutdown();
7988        _result
7989    }
7990
7991    /// Similar to "send" but does not shutdown the channel if an error occurs.
7992    pub fn send_no_shutdown_on_err(self, mut version: u64) -> Result<(), fidl::Error> {
7993        let _result = self.send_raw(version);
7994        self.drop_without_shutdown();
7995        _result
7996    }
7997
7998    fn send_raw(&self, mut version: u64) -> Result<(), fidl::Error> {
7999        self.control_handle.inner.send::<RunnerGetVersionResponse>(
8000            (version,),
8001            self.tx_id,
8002            0x555d1430b913cdd4,
8003            fidl::encoding::DynamicFlags::empty(),
8004        )
8005    }
8006}
8007
8008#[must_use = "FIDL methods require a response to be sent"]
8009#[derive(Debug)]
8010pub struct RunnerIsTestEnabledResponder {
8011    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
8012    tx_id: u32,
8013}
8014
8015/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
8016/// if the responder is dropped without sending a response, so that the client
8017/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
8018impl std::ops::Drop for RunnerIsTestEnabledResponder {
8019    fn drop(&mut self) {
8020        self.control_handle.shutdown();
8021        // Safety: drops once, never accessed again
8022        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8023    }
8024}
8025
8026impl fidl::endpoints::Responder for RunnerIsTestEnabledResponder {
8027    type ControlHandle = RunnerControlHandle;
8028
8029    fn control_handle(&self) -> &RunnerControlHandle {
8030        &self.control_handle
8031    }
8032
8033    fn drop_without_shutdown(mut self) {
8034        // Safety: drops once, never accessed again due to mem::forget
8035        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8036        // Prevent Drop from running (which would shut down the channel)
8037        std::mem::forget(self);
8038    }
8039}
8040
8041impl RunnerIsTestEnabledResponder {
8042    /// Sends a response to the FIDL transaction.
8043    ///
8044    /// Sets the channel to shutdown if an error occurs.
8045    pub fn send(self, mut is_enabled: bool) -> Result<(), fidl::Error> {
8046        let _result = self.send_raw(is_enabled);
8047        if _result.is_err() {
8048            self.control_handle.shutdown();
8049        }
8050        self.drop_without_shutdown();
8051        _result
8052    }
8053
8054    /// Similar to "send" but does not shutdown the channel if an error occurs.
8055    pub fn send_no_shutdown_on_err(self, mut is_enabled: bool) -> Result<(), fidl::Error> {
8056        let _result = self.send_raw(is_enabled);
8057        self.drop_without_shutdown();
8058        _result
8059    }
8060
8061    fn send_raw(&self, mut is_enabled: bool) -> Result<(), fidl::Error> {
8062        self.control_handle.inner.send::<RunnerIsTestEnabledResponse>(
8063            (is_enabled,),
8064            self.tx_id,
8065            0x755bc493368d7c50,
8066            fidl::encoding::DynamicFlags::empty(),
8067        )
8068    }
8069}
8070
8071#[must_use = "FIDL methods require a response to be sent"]
8072#[derive(Debug)]
8073pub struct RunnerCheckAliveResponder {
8074    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
8075    tx_id: u32,
8076}
8077
8078/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
8079/// if the responder is dropped without sending a response, so that the client
8080/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
8081impl std::ops::Drop for RunnerCheckAliveResponder {
8082    fn drop(&mut self) {
8083        self.control_handle.shutdown();
8084        // Safety: drops once, never accessed again
8085        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8086    }
8087}
8088
8089impl fidl::endpoints::Responder for RunnerCheckAliveResponder {
8090    type ControlHandle = RunnerControlHandle;
8091
8092    fn control_handle(&self) -> &RunnerControlHandle {
8093        &self.control_handle
8094    }
8095
8096    fn drop_without_shutdown(mut self) {
8097        // Safety: drops once, never accessed again due to mem::forget
8098        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8099        // Prevent Drop from running (which would shut down the channel)
8100        std::mem::forget(self);
8101    }
8102}
8103
8104impl RunnerCheckAliveResponder {
8105    /// Sends a response to the FIDL transaction.
8106    ///
8107    /// Sets the channel to shutdown if an error occurs.
8108    pub fn send(self) -> Result<(), fidl::Error> {
8109        let _result = self.send_raw();
8110        if _result.is_err() {
8111            self.control_handle.shutdown();
8112        }
8113        self.drop_without_shutdown();
8114        _result
8115    }
8116
8117    /// Similar to "send" but does not shutdown the channel if an error occurs.
8118    pub fn send_no_shutdown_on_err(self) -> Result<(), fidl::Error> {
8119        let _result = self.send_raw();
8120        self.drop_without_shutdown();
8121        _result
8122    }
8123
8124    fn send_raw(&self) -> Result<(), fidl::Error> {
8125        self.control_handle.inner.send::<fidl::encoding::EmptyPayload>(
8126            (),
8127            self.tx_id,
8128            0x5a77b04abdfde130,
8129            fidl::encoding::DynamicFlags::empty(),
8130        )
8131    }
8132}
8133
8134#[must_use = "FIDL methods require a response to be sent"]
8135#[derive(Debug)]
8136pub struct RunnerGetBindingsPropertiesResponder {
8137    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
8138    tx_id: u32,
8139}
8140
8141/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
8142/// if the responder is dropped without sending a response, so that the client
8143/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
8144impl std::ops::Drop for RunnerGetBindingsPropertiesResponder {
8145    fn drop(&mut self) {
8146        self.control_handle.shutdown();
8147        // Safety: drops once, never accessed again
8148        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8149    }
8150}
8151
8152impl fidl::endpoints::Responder for RunnerGetBindingsPropertiesResponder {
8153    type ControlHandle = RunnerControlHandle;
8154
8155    fn control_handle(&self) -> &RunnerControlHandle {
8156        &self.control_handle
8157    }
8158
8159    fn drop_without_shutdown(mut self) {
8160        // Safety: drops once, never accessed again due to mem::forget
8161        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8162        // Prevent Drop from running (which would shut down the channel)
8163        std::mem::forget(self);
8164    }
8165}
8166
8167impl RunnerGetBindingsPropertiesResponder {
8168    /// Sends a response to the FIDL transaction.
8169    ///
8170    /// Sets the channel to shutdown if an error occurs.
8171    pub fn send(self, mut payload: &BindingsProperties) -> Result<(), fidl::Error> {
8172        let _result = self.send_raw(payload);
8173        if _result.is_err() {
8174            self.control_handle.shutdown();
8175        }
8176        self.drop_without_shutdown();
8177        _result
8178    }
8179
8180    /// Similar to "send" but does not shutdown the channel if an error occurs.
8181    pub fn send_no_shutdown_on_err(
8182        self,
8183        mut payload: &BindingsProperties,
8184    ) -> Result<(), fidl::Error> {
8185        let _result = self.send_raw(payload);
8186        self.drop_without_shutdown();
8187        _result
8188    }
8189
8190    fn send_raw(&self, mut payload: &BindingsProperties) -> Result<(), fidl::Error> {
8191        self.control_handle.inner.send::<BindingsProperties>(
8192            payload,
8193            self.tx_id,
8194            0x76b5610bfd4fa636,
8195            fidl::encoding::DynamicFlags::empty(),
8196        )
8197    }
8198}
8199
8200#[must_use = "FIDL methods require a response to be sent"]
8201#[derive(Debug)]
8202pub struct RunnerCallTwoWayNoPayloadResponder {
8203    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
8204    tx_id: u32,
8205}
8206
8207/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
8208/// if the responder is dropped without sending a response, so that the client
8209/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
8210impl std::ops::Drop for RunnerCallTwoWayNoPayloadResponder {
8211    fn drop(&mut self) {
8212        self.control_handle.shutdown();
8213        // Safety: drops once, never accessed again
8214        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8215    }
8216}
8217
8218impl fidl::endpoints::Responder for RunnerCallTwoWayNoPayloadResponder {
8219    type ControlHandle = RunnerControlHandle;
8220
8221    fn control_handle(&self) -> &RunnerControlHandle {
8222        &self.control_handle
8223    }
8224
8225    fn drop_without_shutdown(mut self) {
8226        // Safety: drops once, never accessed again due to mem::forget
8227        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8228        // Prevent Drop from running (which would shut down the channel)
8229        std::mem::forget(self);
8230    }
8231}
8232
8233impl RunnerCallTwoWayNoPayloadResponder {
8234    /// Sends a response to the FIDL transaction.
8235    ///
8236    /// Sets the channel to shutdown if an error occurs.
8237    pub fn send(self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
8238        let _result = self.send_raw(payload);
8239        if _result.is_err() {
8240            self.control_handle.shutdown();
8241        }
8242        self.drop_without_shutdown();
8243        _result
8244    }
8245
8246    /// Similar to "send" but does not shutdown the channel if an error occurs.
8247    pub fn send_no_shutdown_on_err(
8248        self,
8249        mut payload: &EmptyResultClassification,
8250    ) -> Result<(), fidl::Error> {
8251        let _result = self.send_raw(payload);
8252        self.drop_without_shutdown();
8253        _result
8254    }
8255
8256    fn send_raw(&self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
8257        self.control_handle.inner.send::<EmptyResultClassification>(
8258            payload,
8259            self.tx_id,
8260            0x53ac710c20b320a1,
8261            fidl::encoding::DynamicFlags::empty(),
8262        )
8263    }
8264}
8265
8266#[must_use = "FIDL methods require a response to be sent"]
8267#[derive(Debug)]
8268pub struct RunnerCallTwoWayStructPayloadResponder {
8269    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
8270    tx_id: u32,
8271}
8272
8273/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
8274/// if the responder is dropped without sending a response, so that the client
8275/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
8276impl std::ops::Drop for RunnerCallTwoWayStructPayloadResponder {
8277    fn drop(&mut self) {
8278        self.control_handle.shutdown();
8279        // Safety: drops once, never accessed again
8280        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8281    }
8282}
8283
8284impl fidl::endpoints::Responder for RunnerCallTwoWayStructPayloadResponder {
8285    type ControlHandle = RunnerControlHandle;
8286
8287    fn control_handle(&self) -> &RunnerControlHandle {
8288        &self.control_handle
8289    }
8290
8291    fn drop_without_shutdown(mut self) {
8292        // Safety: drops once, never accessed again due to mem::forget
8293        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8294        // Prevent Drop from running (which would shut down the channel)
8295        std::mem::forget(self);
8296    }
8297}
8298
8299impl RunnerCallTwoWayStructPayloadResponder {
8300    /// Sends a response to the FIDL transaction.
8301    ///
8302    /// Sets the channel to shutdown if an error occurs.
8303    pub fn send(self, mut payload: &NonEmptyResultClassification) -> Result<(), fidl::Error> {
8304        let _result = self.send_raw(payload);
8305        if _result.is_err() {
8306            self.control_handle.shutdown();
8307        }
8308        self.drop_without_shutdown();
8309        _result
8310    }
8311
8312    /// Similar to "send" but does not shutdown the channel if an error occurs.
8313    pub fn send_no_shutdown_on_err(
8314        self,
8315        mut payload: &NonEmptyResultClassification,
8316    ) -> Result<(), fidl::Error> {
8317        let _result = self.send_raw(payload);
8318        self.drop_without_shutdown();
8319        _result
8320    }
8321
8322    fn send_raw(&self, mut payload: &NonEmptyResultClassification) -> Result<(), fidl::Error> {
8323        self.control_handle.inner.send::<NonEmptyResultClassification>(
8324            payload,
8325            self.tx_id,
8326            0x24e98c668499b946,
8327            fidl::encoding::DynamicFlags::empty(),
8328        )
8329    }
8330}
8331
8332#[must_use = "FIDL methods require a response to be sent"]
8333#[derive(Debug)]
8334pub struct RunnerCallTwoWayTablePayloadResponder {
8335    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
8336    tx_id: u32,
8337}
8338
8339/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
8340/// if the responder is dropped without sending a response, so that the client
8341/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
8342impl std::ops::Drop for RunnerCallTwoWayTablePayloadResponder {
8343    fn drop(&mut self) {
8344        self.control_handle.shutdown();
8345        // Safety: drops once, never accessed again
8346        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8347    }
8348}
8349
8350impl fidl::endpoints::Responder for RunnerCallTwoWayTablePayloadResponder {
8351    type ControlHandle = RunnerControlHandle;
8352
8353    fn control_handle(&self) -> &RunnerControlHandle {
8354        &self.control_handle
8355    }
8356
8357    fn drop_without_shutdown(mut self) {
8358        // Safety: drops once, never accessed again due to mem::forget
8359        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8360        // Prevent Drop from running (which would shut down the channel)
8361        std::mem::forget(self);
8362    }
8363}
8364
8365impl RunnerCallTwoWayTablePayloadResponder {
8366    /// Sends a response to the FIDL transaction.
8367    ///
8368    /// Sets the channel to shutdown if an error occurs.
8369    pub fn send(self, mut payload: &TableResultClassification) -> Result<(), fidl::Error> {
8370        let _result = self.send_raw(payload);
8371        if _result.is_err() {
8372            self.control_handle.shutdown();
8373        }
8374        self.drop_without_shutdown();
8375        _result
8376    }
8377
8378    /// Similar to "send" but does not shutdown the channel if an error occurs.
8379    pub fn send_no_shutdown_on_err(
8380        self,
8381        mut payload: &TableResultClassification,
8382    ) -> Result<(), fidl::Error> {
8383        let _result = self.send_raw(payload);
8384        self.drop_without_shutdown();
8385        _result
8386    }
8387
8388    fn send_raw(&self, mut payload: &TableResultClassification) -> Result<(), fidl::Error> {
8389        self.control_handle.inner.send::<TableResultClassification>(
8390            payload,
8391            self.tx_id,
8392            0x72e428e1605b76a,
8393            fidl::encoding::DynamicFlags::empty(),
8394        )
8395    }
8396}
8397
8398#[must_use = "FIDL methods require a response to be sent"]
8399#[derive(Debug)]
8400pub struct RunnerCallTwoWayUnionPayloadResponder {
8401    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
8402    tx_id: u32,
8403}
8404
8405/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
8406/// if the responder is dropped without sending a response, so that the client
8407/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
8408impl std::ops::Drop for RunnerCallTwoWayUnionPayloadResponder {
8409    fn drop(&mut self) {
8410        self.control_handle.shutdown();
8411        // Safety: drops once, never accessed again
8412        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8413    }
8414}
8415
8416impl fidl::endpoints::Responder for RunnerCallTwoWayUnionPayloadResponder {
8417    type ControlHandle = RunnerControlHandle;
8418
8419    fn control_handle(&self) -> &RunnerControlHandle {
8420        &self.control_handle
8421    }
8422
8423    fn drop_without_shutdown(mut self) {
8424        // Safety: drops once, never accessed again due to mem::forget
8425        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8426        // Prevent Drop from running (which would shut down the channel)
8427        std::mem::forget(self);
8428    }
8429}
8430
8431impl RunnerCallTwoWayUnionPayloadResponder {
8432    /// Sends a response to the FIDL transaction.
8433    ///
8434    /// Sets the channel to shutdown if an error occurs.
8435    pub fn send(self, mut payload: &UnionResultClassification) -> Result<(), fidl::Error> {
8436        let _result = self.send_raw(payload);
8437        if _result.is_err() {
8438            self.control_handle.shutdown();
8439        }
8440        self.drop_without_shutdown();
8441        _result
8442    }
8443
8444    /// Similar to "send" but does not shutdown the channel if an error occurs.
8445    pub fn send_no_shutdown_on_err(
8446        self,
8447        mut payload: &UnionResultClassification,
8448    ) -> Result<(), fidl::Error> {
8449        let _result = self.send_raw(payload);
8450        self.drop_without_shutdown();
8451        _result
8452    }
8453
8454    fn send_raw(&self, mut payload: &UnionResultClassification) -> Result<(), fidl::Error> {
8455        self.control_handle.inner.send::<UnionResultClassification>(
8456            payload,
8457            self.tx_id,
8458            0x7dc9d67218343860,
8459            fidl::encoding::DynamicFlags::empty(),
8460        )
8461    }
8462}
8463
8464#[must_use = "FIDL methods require a response to be sent"]
8465#[derive(Debug)]
8466pub struct RunnerCallTwoWayStructPayloadErrResponder {
8467    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
8468    tx_id: u32,
8469}
8470
8471/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
8472/// if the responder is dropped without sending a response, so that the client
8473/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
8474impl std::ops::Drop for RunnerCallTwoWayStructPayloadErrResponder {
8475    fn drop(&mut self) {
8476        self.control_handle.shutdown();
8477        // Safety: drops once, never accessed again
8478        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8479    }
8480}
8481
8482impl fidl::endpoints::Responder for RunnerCallTwoWayStructPayloadErrResponder {
8483    type ControlHandle = RunnerControlHandle;
8484
8485    fn control_handle(&self) -> &RunnerControlHandle {
8486        &self.control_handle
8487    }
8488
8489    fn drop_without_shutdown(mut self) {
8490        // Safety: drops once, never accessed again due to mem::forget
8491        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8492        // Prevent Drop from running (which would shut down the channel)
8493        std::mem::forget(self);
8494    }
8495}
8496
8497impl RunnerCallTwoWayStructPayloadErrResponder {
8498    /// Sends a response to the FIDL transaction.
8499    ///
8500    /// Sets the channel to shutdown if an error occurs.
8501    pub fn send(
8502        self,
8503        mut payload: &NonEmptyResultWithErrorClassification,
8504    ) -> Result<(), fidl::Error> {
8505        let _result = self.send_raw(payload);
8506        if _result.is_err() {
8507            self.control_handle.shutdown();
8508        }
8509        self.drop_without_shutdown();
8510        _result
8511    }
8512
8513    /// Similar to "send" but does not shutdown the channel if an error occurs.
8514    pub fn send_no_shutdown_on_err(
8515        self,
8516        mut payload: &NonEmptyResultWithErrorClassification,
8517    ) -> Result<(), fidl::Error> {
8518        let _result = self.send_raw(payload);
8519        self.drop_without_shutdown();
8520        _result
8521    }
8522
8523    fn send_raw(
8524        &self,
8525        mut payload: &NonEmptyResultWithErrorClassification,
8526    ) -> Result<(), fidl::Error> {
8527        self.control_handle.inner.send::<NonEmptyResultWithErrorClassification>(
8528            payload,
8529            self.tx_id,
8530            0x2b07a57942c5f6e5,
8531            fidl::encoding::DynamicFlags::empty(),
8532        )
8533    }
8534}
8535
8536#[must_use = "FIDL methods require a response to be sent"]
8537#[derive(Debug)]
8538pub struct RunnerCallTwoWayStructRequestResponder {
8539    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
8540    tx_id: u32,
8541}
8542
8543/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
8544/// if the responder is dropped without sending a response, so that the client
8545/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
8546impl std::ops::Drop for RunnerCallTwoWayStructRequestResponder {
8547    fn drop(&mut self) {
8548        self.control_handle.shutdown();
8549        // Safety: drops once, never accessed again
8550        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8551    }
8552}
8553
8554impl fidl::endpoints::Responder for RunnerCallTwoWayStructRequestResponder {
8555    type ControlHandle = RunnerControlHandle;
8556
8557    fn control_handle(&self) -> &RunnerControlHandle {
8558        &self.control_handle
8559    }
8560
8561    fn drop_without_shutdown(mut self) {
8562        // Safety: drops once, never accessed again due to mem::forget
8563        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8564        // Prevent Drop from running (which would shut down the channel)
8565        std::mem::forget(self);
8566    }
8567}
8568
8569impl RunnerCallTwoWayStructRequestResponder {
8570    /// Sends a response to the FIDL transaction.
8571    ///
8572    /// Sets the channel to shutdown if an error occurs.
8573    pub fn send(self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
8574        let _result = self.send_raw(payload);
8575        if _result.is_err() {
8576            self.control_handle.shutdown();
8577        }
8578        self.drop_without_shutdown();
8579        _result
8580    }
8581
8582    /// Similar to "send" but does not shutdown the channel if an error occurs.
8583    pub fn send_no_shutdown_on_err(
8584        self,
8585        mut payload: &EmptyResultClassification,
8586    ) -> Result<(), fidl::Error> {
8587        let _result = self.send_raw(payload);
8588        self.drop_without_shutdown();
8589        _result
8590    }
8591
8592    fn send_raw(&self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
8593        self.control_handle.inner.send::<EmptyResultClassification>(
8594            payload,
8595            self.tx_id,
8596            0x7c00a6ba2e6c9b45,
8597            fidl::encoding::DynamicFlags::empty(),
8598        )
8599    }
8600}
8601
8602#[must_use = "FIDL methods require a response to be sent"]
8603#[derive(Debug)]
8604pub struct RunnerCallTwoWayTableRequestResponder {
8605    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
8606    tx_id: u32,
8607}
8608
8609/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
8610/// if the responder is dropped without sending a response, so that the client
8611/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
8612impl std::ops::Drop for RunnerCallTwoWayTableRequestResponder {
8613    fn drop(&mut self) {
8614        self.control_handle.shutdown();
8615        // Safety: drops once, never accessed again
8616        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8617    }
8618}
8619
8620impl fidl::endpoints::Responder for RunnerCallTwoWayTableRequestResponder {
8621    type ControlHandle = RunnerControlHandle;
8622
8623    fn control_handle(&self) -> &RunnerControlHandle {
8624        &self.control_handle
8625    }
8626
8627    fn drop_without_shutdown(mut self) {
8628        // Safety: drops once, never accessed again due to mem::forget
8629        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8630        // Prevent Drop from running (which would shut down the channel)
8631        std::mem::forget(self);
8632    }
8633}
8634
8635impl RunnerCallTwoWayTableRequestResponder {
8636    /// Sends a response to the FIDL transaction.
8637    ///
8638    /// Sets the channel to shutdown if an error occurs.
8639    pub fn send(self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
8640        let _result = self.send_raw(payload);
8641        if _result.is_err() {
8642            self.control_handle.shutdown();
8643        }
8644        self.drop_without_shutdown();
8645        _result
8646    }
8647
8648    /// Similar to "send" but does not shutdown the channel if an error occurs.
8649    pub fn send_no_shutdown_on_err(
8650        self,
8651        mut payload: &EmptyResultClassification,
8652    ) -> Result<(), fidl::Error> {
8653        let _result = self.send_raw(payload);
8654        self.drop_without_shutdown();
8655        _result
8656    }
8657
8658    fn send_raw(&self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
8659        self.control_handle.inner.send::<EmptyResultClassification>(
8660            payload,
8661            self.tx_id,
8662            0x641763237d3885be,
8663            fidl::encoding::DynamicFlags::empty(),
8664        )
8665    }
8666}
8667
8668#[must_use = "FIDL methods require a response to be sent"]
8669#[derive(Debug)]
8670pub struct RunnerCallTwoWayUnionRequestResponder {
8671    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
8672    tx_id: u32,
8673}
8674
8675/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
8676/// if the responder is dropped without sending a response, so that the client
8677/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
8678impl std::ops::Drop for RunnerCallTwoWayUnionRequestResponder {
8679    fn drop(&mut self) {
8680        self.control_handle.shutdown();
8681        // Safety: drops once, never accessed again
8682        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8683    }
8684}
8685
8686impl fidl::endpoints::Responder for RunnerCallTwoWayUnionRequestResponder {
8687    type ControlHandle = RunnerControlHandle;
8688
8689    fn control_handle(&self) -> &RunnerControlHandle {
8690        &self.control_handle
8691    }
8692
8693    fn drop_without_shutdown(mut self) {
8694        // Safety: drops once, never accessed again due to mem::forget
8695        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8696        // Prevent Drop from running (which would shut down the channel)
8697        std::mem::forget(self);
8698    }
8699}
8700
8701impl RunnerCallTwoWayUnionRequestResponder {
8702    /// Sends a response to the FIDL transaction.
8703    ///
8704    /// Sets the channel to shutdown if an error occurs.
8705    pub fn send(self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
8706        let _result = self.send_raw(payload);
8707        if _result.is_err() {
8708            self.control_handle.shutdown();
8709        }
8710        self.drop_without_shutdown();
8711        _result
8712    }
8713
8714    /// Similar to "send" but does not shutdown the channel if an error occurs.
8715    pub fn send_no_shutdown_on_err(
8716        self,
8717        mut payload: &EmptyResultClassification,
8718    ) -> Result<(), fidl::Error> {
8719        let _result = self.send_raw(payload);
8720        self.drop_without_shutdown();
8721        _result
8722    }
8723
8724    fn send_raw(&self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
8725        self.control_handle.inner.send::<EmptyResultClassification>(
8726            payload,
8727            self.tx_id,
8728            0x4be5f061df42619e,
8729            fidl::encoding::DynamicFlags::empty(),
8730        )
8731    }
8732}
8733
8734#[must_use = "FIDL methods require a response to be sent"]
8735#[derive(Debug)]
8736pub struct RunnerCallOneWayNoRequestResponder {
8737    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
8738    tx_id: u32,
8739}
8740
8741/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
8742/// if the responder is dropped without sending a response, so that the client
8743/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
8744impl std::ops::Drop for RunnerCallOneWayNoRequestResponder {
8745    fn drop(&mut self) {
8746        self.control_handle.shutdown();
8747        // Safety: drops once, never accessed again
8748        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8749    }
8750}
8751
8752impl fidl::endpoints::Responder for RunnerCallOneWayNoRequestResponder {
8753    type ControlHandle = RunnerControlHandle;
8754
8755    fn control_handle(&self) -> &RunnerControlHandle {
8756        &self.control_handle
8757    }
8758
8759    fn drop_without_shutdown(mut self) {
8760        // Safety: drops once, never accessed again due to mem::forget
8761        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8762        // Prevent Drop from running (which would shut down the channel)
8763        std::mem::forget(self);
8764    }
8765}
8766
8767impl RunnerCallOneWayNoRequestResponder {
8768    /// Sends a response to the FIDL transaction.
8769    ///
8770    /// Sets the channel to shutdown if an error occurs.
8771    pub fn send(self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
8772        let _result = self.send_raw(payload);
8773        if _result.is_err() {
8774            self.control_handle.shutdown();
8775        }
8776        self.drop_without_shutdown();
8777        _result
8778    }
8779
8780    /// Similar to "send" but does not shutdown the channel if an error occurs.
8781    pub fn send_no_shutdown_on_err(
8782        self,
8783        mut payload: &EmptyResultClassification,
8784    ) -> Result<(), fidl::Error> {
8785        let _result = self.send_raw(payload);
8786        self.drop_without_shutdown();
8787        _result
8788    }
8789
8790    fn send_raw(&self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
8791        self.control_handle.inner.send::<EmptyResultClassification>(
8792            payload,
8793            self.tx_id,
8794            0x24b6eea8cbdccc09,
8795            fidl::encoding::DynamicFlags::empty(),
8796        )
8797    }
8798}
8799
8800#[must_use = "FIDL methods require a response to be sent"]
8801#[derive(Debug)]
8802pub struct RunnerCallOneWayStructRequestResponder {
8803    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
8804    tx_id: u32,
8805}
8806
8807/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
8808/// if the responder is dropped without sending a response, so that the client
8809/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
8810impl std::ops::Drop for RunnerCallOneWayStructRequestResponder {
8811    fn drop(&mut self) {
8812        self.control_handle.shutdown();
8813        // Safety: drops once, never accessed again
8814        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8815    }
8816}
8817
8818impl fidl::endpoints::Responder for RunnerCallOneWayStructRequestResponder {
8819    type ControlHandle = RunnerControlHandle;
8820
8821    fn control_handle(&self) -> &RunnerControlHandle {
8822        &self.control_handle
8823    }
8824
8825    fn drop_without_shutdown(mut self) {
8826        // Safety: drops once, never accessed again due to mem::forget
8827        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8828        // Prevent Drop from running (which would shut down the channel)
8829        std::mem::forget(self);
8830    }
8831}
8832
8833impl RunnerCallOneWayStructRequestResponder {
8834    /// Sends a response to the FIDL transaction.
8835    ///
8836    /// Sets the channel to shutdown if an error occurs.
8837    pub fn send(self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
8838        let _result = self.send_raw(payload);
8839        if _result.is_err() {
8840            self.control_handle.shutdown();
8841        }
8842        self.drop_without_shutdown();
8843        _result
8844    }
8845
8846    /// Similar to "send" but does not shutdown the channel if an error occurs.
8847    pub fn send_no_shutdown_on_err(
8848        self,
8849        mut payload: &EmptyResultClassification,
8850    ) -> Result<(), fidl::Error> {
8851        let _result = self.send_raw(payload);
8852        self.drop_without_shutdown();
8853        _result
8854    }
8855
8856    fn send_raw(&self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
8857        self.control_handle.inner.send::<EmptyResultClassification>(
8858            payload,
8859            self.tx_id,
8860            0x352a2907a0fcb420,
8861            fidl::encoding::DynamicFlags::empty(),
8862        )
8863    }
8864}
8865
8866#[must_use = "FIDL methods require a response to be sent"]
8867#[derive(Debug)]
8868pub struct RunnerCallOneWayTableRequestResponder {
8869    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
8870    tx_id: u32,
8871}
8872
8873/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
8874/// if the responder is dropped without sending a response, so that the client
8875/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
8876impl std::ops::Drop for RunnerCallOneWayTableRequestResponder {
8877    fn drop(&mut self) {
8878        self.control_handle.shutdown();
8879        // Safety: drops once, never accessed again
8880        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8881    }
8882}
8883
8884impl fidl::endpoints::Responder for RunnerCallOneWayTableRequestResponder {
8885    type ControlHandle = RunnerControlHandle;
8886
8887    fn control_handle(&self) -> &RunnerControlHandle {
8888        &self.control_handle
8889    }
8890
8891    fn drop_without_shutdown(mut self) {
8892        // Safety: drops once, never accessed again due to mem::forget
8893        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8894        // Prevent Drop from running (which would shut down the channel)
8895        std::mem::forget(self);
8896    }
8897}
8898
8899impl RunnerCallOneWayTableRequestResponder {
8900    /// Sends a response to the FIDL transaction.
8901    ///
8902    /// Sets the channel to shutdown if an error occurs.
8903    pub fn send(self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
8904        let _result = self.send_raw(payload);
8905        if _result.is_err() {
8906            self.control_handle.shutdown();
8907        }
8908        self.drop_without_shutdown();
8909        _result
8910    }
8911
8912    /// Similar to "send" but does not shutdown the channel if an error occurs.
8913    pub fn send_no_shutdown_on_err(
8914        self,
8915        mut payload: &EmptyResultClassification,
8916    ) -> Result<(), fidl::Error> {
8917        let _result = self.send_raw(payload);
8918        self.drop_without_shutdown();
8919        _result
8920    }
8921
8922    fn send_raw(&self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
8923        self.control_handle.inner.send::<EmptyResultClassification>(
8924            payload,
8925            self.tx_id,
8926            0x734121bf8bf336ef,
8927            fidl::encoding::DynamicFlags::empty(),
8928        )
8929    }
8930}
8931
8932#[must_use = "FIDL methods require a response to be sent"]
8933#[derive(Debug)]
8934pub struct RunnerCallOneWayUnionRequestResponder {
8935    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
8936    tx_id: u32,
8937}
8938
8939/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
8940/// if the responder is dropped without sending a response, so that the client
8941/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
8942impl std::ops::Drop for RunnerCallOneWayUnionRequestResponder {
8943    fn drop(&mut self) {
8944        self.control_handle.shutdown();
8945        // Safety: drops once, never accessed again
8946        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8947    }
8948}
8949
8950impl fidl::endpoints::Responder for RunnerCallOneWayUnionRequestResponder {
8951    type ControlHandle = RunnerControlHandle;
8952
8953    fn control_handle(&self) -> &RunnerControlHandle {
8954        &self.control_handle
8955    }
8956
8957    fn drop_without_shutdown(mut self) {
8958        // Safety: drops once, never accessed again due to mem::forget
8959        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
8960        // Prevent Drop from running (which would shut down the channel)
8961        std::mem::forget(self);
8962    }
8963}
8964
8965impl RunnerCallOneWayUnionRequestResponder {
8966    /// Sends a response to the FIDL transaction.
8967    ///
8968    /// Sets the channel to shutdown if an error occurs.
8969    pub fn send(self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
8970        let _result = self.send_raw(payload);
8971        if _result.is_err() {
8972            self.control_handle.shutdown();
8973        }
8974        self.drop_without_shutdown();
8975        _result
8976    }
8977
8978    /// Similar to "send" but does not shutdown the channel if an error occurs.
8979    pub fn send_no_shutdown_on_err(
8980        self,
8981        mut payload: &EmptyResultClassification,
8982    ) -> Result<(), fidl::Error> {
8983        let _result = self.send_raw(payload);
8984        self.drop_without_shutdown();
8985        _result
8986    }
8987
8988    fn send_raw(&self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
8989        self.control_handle.inner.send::<EmptyResultClassification>(
8990            payload,
8991            self.tx_id,
8992            0x9be8e5eb7d50eb6,
8993            fidl::encoding::DynamicFlags::empty(),
8994        )
8995    }
8996}
8997
8998#[must_use = "FIDL methods require a response to be sent"]
8999#[derive(Debug)]
9000pub struct RunnerCallStrictOneWayResponder {
9001    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
9002    tx_id: u32,
9003}
9004
9005/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
9006/// if the responder is dropped without sending a response, so that the client
9007/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
9008impl std::ops::Drop for RunnerCallStrictOneWayResponder {
9009    fn drop(&mut self) {
9010        self.control_handle.shutdown();
9011        // Safety: drops once, never accessed again
9012        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9013    }
9014}
9015
9016impl fidl::endpoints::Responder for RunnerCallStrictOneWayResponder {
9017    type ControlHandle = RunnerControlHandle;
9018
9019    fn control_handle(&self) -> &RunnerControlHandle {
9020        &self.control_handle
9021    }
9022
9023    fn drop_without_shutdown(mut self) {
9024        // Safety: drops once, never accessed again due to mem::forget
9025        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9026        // Prevent Drop from running (which would shut down the channel)
9027        std::mem::forget(self);
9028    }
9029}
9030
9031impl RunnerCallStrictOneWayResponder {
9032    /// Sends a response to the FIDL transaction.
9033    ///
9034    /// Sets the channel to shutdown if an error occurs.
9035    pub fn send(self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
9036        let _result = self.send_raw(payload);
9037        if _result.is_err() {
9038            self.control_handle.shutdown();
9039        }
9040        self.drop_without_shutdown();
9041        _result
9042    }
9043
9044    /// Similar to "send" but does not shutdown the channel if an error occurs.
9045    pub fn send_no_shutdown_on_err(
9046        self,
9047        mut payload: &EmptyResultClassification,
9048    ) -> Result<(), fidl::Error> {
9049        let _result = self.send_raw(payload);
9050        self.drop_without_shutdown();
9051        _result
9052    }
9053
9054    fn send_raw(&self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
9055        self.control_handle.inner.send::<EmptyResultClassification>(
9056            payload,
9057            self.tx_id,
9058            0x4edd0b6f52c0446b,
9059            fidl::encoding::DynamicFlags::empty(),
9060        )
9061    }
9062}
9063
9064#[must_use = "FIDL methods require a response to be sent"]
9065#[derive(Debug)]
9066pub struct RunnerCallFlexibleOneWayResponder {
9067    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
9068    tx_id: u32,
9069}
9070
9071/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
9072/// if the responder is dropped without sending a response, so that the client
9073/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
9074impl std::ops::Drop for RunnerCallFlexibleOneWayResponder {
9075    fn drop(&mut self) {
9076        self.control_handle.shutdown();
9077        // Safety: drops once, never accessed again
9078        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9079    }
9080}
9081
9082impl fidl::endpoints::Responder for RunnerCallFlexibleOneWayResponder {
9083    type ControlHandle = RunnerControlHandle;
9084
9085    fn control_handle(&self) -> &RunnerControlHandle {
9086        &self.control_handle
9087    }
9088
9089    fn drop_without_shutdown(mut self) {
9090        // Safety: drops once, never accessed again due to mem::forget
9091        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9092        // Prevent Drop from running (which would shut down the channel)
9093        std::mem::forget(self);
9094    }
9095}
9096
9097impl RunnerCallFlexibleOneWayResponder {
9098    /// Sends a response to the FIDL transaction.
9099    ///
9100    /// Sets the channel to shutdown if an error occurs.
9101    pub fn send(self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
9102        let _result = self.send_raw(payload);
9103        if _result.is_err() {
9104            self.control_handle.shutdown();
9105        }
9106        self.drop_without_shutdown();
9107        _result
9108    }
9109
9110    /// Similar to "send" but does not shutdown the channel if an error occurs.
9111    pub fn send_no_shutdown_on_err(
9112        self,
9113        mut payload: &EmptyResultClassification,
9114    ) -> Result<(), fidl::Error> {
9115        let _result = self.send_raw(payload);
9116        self.drop_without_shutdown();
9117        _result
9118    }
9119
9120    fn send_raw(&self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
9121        self.control_handle.inner.send::<EmptyResultClassification>(
9122            payload,
9123            self.tx_id,
9124            0x7253f10a77dfe817,
9125            fidl::encoding::DynamicFlags::empty(),
9126        )
9127    }
9128}
9129
9130#[must_use = "FIDL methods require a response to be sent"]
9131#[derive(Debug)]
9132pub struct RunnerCallStrictTwoWayResponder {
9133    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
9134    tx_id: u32,
9135}
9136
9137/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
9138/// if the responder is dropped without sending a response, so that the client
9139/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
9140impl std::ops::Drop for RunnerCallStrictTwoWayResponder {
9141    fn drop(&mut self) {
9142        self.control_handle.shutdown();
9143        // Safety: drops once, never accessed again
9144        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9145    }
9146}
9147
9148impl fidl::endpoints::Responder for RunnerCallStrictTwoWayResponder {
9149    type ControlHandle = RunnerControlHandle;
9150
9151    fn control_handle(&self) -> &RunnerControlHandle {
9152        &self.control_handle
9153    }
9154
9155    fn drop_without_shutdown(mut self) {
9156        // Safety: drops once, never accessed again due to mem::forget
9157        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9158        // Prevent Drop from running (which would shut down the channel)
9159        std::mem::forget(self);
9160    }
9161}
9162
9163impl RunnerCallStrictTwoWayResponder {
9164    /// Sends a response to the FIDL transaction.
9165    ///
9166    /// Sets the channel to shutdown if an error occurs.
9167    pub fn send(self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
9168        let _result = self.send_raw(payload);
9169        if _result.is_err() {
9170            self.control_handle.shutdown();
9171        }
9172        self.drop_without_shutdown();
9173        _result
9174    }
9175
9176    /// Similar to "send" but does not shutdown the channel if an error occurs.
9177    pub fn send_no_shutdown_on_err(
9178        self,
9179        mut payload: &EmptyResultClassification,
9180    ) -> Result<(), fidl::Error> {
9181        let _result = self.send_raw(payload);
9182        self.drop_without_shutdown();
9183        _result
9184    }
9185
9186    fn send_raw(&self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
9187        self.control_handle.inner.send::<EmptyResultClassification>(
9188            payload,
9189            self.tx_id,
9190            0x1fa9fb7414aedd27,
9191            fidl::encoding::DynamicFlags::empty(),
9192        )
9193    }
9194}
9195
9196#[must_use = "FIDL methods require a response to be sent"]
9197#[derive(Debug)]
9198pub struct RunnerCallStrictTwoWayFieldsResponder {
9199    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
9200    tx_id: u32,
9201}
9202
9203/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
9204/// if the responder is dropped without sending a response, so that the client
9205/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
9206impl std::ops::Drop for RunnerCallStrictTwoWayFieldsResponder {
9207    fn drop(&mut self) {
9208        self.control_handle.shutdown();
9209        // Safety: drops once, never accessed again
9210        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9211    }
9212}
9213
9214impl fidl::endpoints::Responder for RunnerCallStrictTwoWayFieldsResponder {
9215    type ControlHandle = RunnerControlHandle;
9216
9217    fn control_handle(&self) -> &RunnerControlHandle {
9218        &self.control_handle
9219    }
9220
9221    fn drop_without_shutdown(mut self) {
9222        // Safety: drops once, never accessed again due to mem::forget
9223        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9224        // Prevent Drop from running (which would shut down the channel)
9225        std::mem::forget(self);
9226    }
9227}
9228
9229impl RunnerCallStrictTwoWayFieldsResponder {
9230    /// Sends a response to the FIDL transaction.
9231    ///
9232    /// Sets the channel to shutdown if an error occurs.
9233    pub fn send(self, mut payload: &NonEmptyResultClassification) -> Result<(), fidl::Error> {
9234        let _result = self.send_raw(payload);
9235        if _result.is_err() {
9236            self.control_handle.shutdown();
9237        }
9238        self.drop_without_shutdown();
9239        _result
9240    }
9241
9242    /// Similar to "send" but does not shutdown the channel if an error occurs.
9243    pub fn send_no_shutdown_on_err(
9244        self,
9245        mut payload: &NonEmptyResultClassification,
9246    ) -> Result<(), fidl::Error> {
9247        let _result = self.send_raw(payload);
9248        self.drop_without_shutdown();
9249        _result
9250    }
9251
9252    fn send_raw(&self, mut payload: &NonEmptyResultClassification) -> Result<(), fidl::Error> {
9253        self.control_handle.inner.send::<NonEmptyResultClassification>(
9254            payload,
9255            self.tx_id,
9256            0x6f690e00ebf6f123,
9257            fidl::encoding::DynamicFlags::empty(),
9258        )
9259    }
9260}
9261
9262#[must_use = "FIDL methods require a response to be sent"]
9263#[derive(Debug)]
9264pub struct RunnerCallStrictTwoWayErrResponder {
9265    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
9266    tx_id: u32,
9267}
9268
9269/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
9270/// if the responder is dropped without sending a response, so that the client
9271/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
9272impl std::ops::Drop for RunnerCallStrictTwoWayErrResponder {
9273    fn drop(&mut self) {
9274        self.control_handle.shutdown();
9275        // Safety: drops once, never accessed again
9276        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9277    }
9278}
9279
9280impl fidl::endpoints::Responder for RunnerCallStrictTwoWayErrResponder {
9281    type ControlHandle = RunnerControlHandle;
9282
9283    fn control_handle(&self) -> &RunnerControlHandle {
9284        &self.control_handle
9285    }
9286
9287    fn drop_without_shutdown(mut self) {
9288        // Safety: drops once, never accessed again due to mem::forget
9289        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9290        // Prevent Drop from running (which would shut down the channel)
9291        std::mem::forget(self);
9292    }
9293}
9294
9295impl RunnerCallStrictTwoWayErrResponder {
9296    /// Sends a response to the FIDL transaction.
9297    ///
9298    /// Sets the channel to shutdown if an error occurs.
9299    pub fn send(self, mut payload: &EmptyResultWithErrorClassification) -> Result<(), fidl::Error> {
9300        let _result = self.send_raw(payload);
9301        if _result.is_err() {
9302            self.control_handle.shutdown();
9303        }
9304        self.drop_without_shutdown();
9305        _result
9306    }
9307
9308    /// Similar to "send" but does not shutdown the channel if an error occurs.
9309    pub fn send_no_shutdown_on_err(
9310        self,
9311        mut payload: &EmptyResultWithErrorClassification,
9312    ) -> Result<(), fidl::Error> {
9313        let _result = self.send_raw(payload);
9314        self.drop_without_shutdown();
9315        _result
9316    }
9317
9318    fn send_raw(
9319        &self,
9320        mut payload: &EmptyResultWithErrorClassification,
9321    ) -> Result<(), fidl::Error> {
9322        self.control_handle.inner.send::<EmptyResultWithErrorClassification>(
9323            payload,
9324            self.tx_id,
9325            0x51d6bc7cf6cbaf1a,
9326            fidl::encoding::DynamicFlags::empty(),
9327        )
9328    }
9329}
9330
9331#[must_use = "FIDL methods require a response to be sent"]
9332#[derive(Debug)]
9333pub struct RunnerCallStrictTwoWayFieldsErrResponder {
9334    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
9335    tx_id: u32,
9336}
9337
9338/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
9339/// if the responder is dropped without sending a response, so that the client
9340/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
9341impl std::ops::Drop for RunnerCallStrictTwoWayFieldsErrResponder {
9342    fn drop(&mut self) {
9343        self.control_handle.shutdown();
9344        // Safety: drops once, never accessed again
9345        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9346    }
9347}
9348
9349impl fidl::endpoints::Responder for RunnerCallStrictTwoWayFieldsErrResponder {
9350    type ControlHandle = RunnerControlHandle;
9351
9352    fn control_handle(&self) -> &RunnerControlHandle {
9353        &self.control_handle
9354    }
9355
9356    fn drop_without_shutdown(mut self) {
9357        // Safety: drops once, never accessed again due to mem::forget
9358        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9359        // Prevent Drop from running (which would shut down the channel)
9360        std::mem::forget(self);
9361    }
9362}
9363
9364impl RunnerCallStrictTwoWayFieldsErrResponder {
9365    /// Sends a response to the FIDL transaction.
9366    ///
9367    /// Sets the channel to shutdown if an error occurs.
9368    pub fn send(
9369        self,
9370        mut payload: &NonEmptyResultWithErrorClassification,
9371    ) -> Result<(), fidl::Error> {
9372        let _result = self.send_raw(payload);
9373        if _result.is_err() {
9374            self.control_handle.shutdown();
9375        }
9376        self.drop_without_shutdown();
9377        _result
9378    }
9379
9380    /// Similar to "send" but does not shutdown the channel if an error occurs.
9381    pub fn send_no_shutdown_on_err(
9382        self,
9383        mut payload: &NonEmptyResultWithErrorClassification,
9384    ) -> Result<(), fidl::Error> {
9385        let _result = self.send_raw(payload);
9386        self.drop_without_shutdown();
9387        _result
9388    }
9389
9390    fn send_raw(
9391        &self,
9392        mut payload: &NonEmptyResultWithErrorClassification,
9393    ) -> Result<(), fidl::Error> {
9394        self.control_handle.inner.send::<NonEmptyResultWithErrorClassification>(
9395            payload,
9396            self.tx_id,
9397            0x6fa31ced05074c05,
9398            fidl::encoding::DynamicFlags::empty(),
9399        )
9400    }
9401}
9402
9403#[must_use = "FIDL methods require a response to be sent"]
9404#[derive(Debug)]
9405pub struct RunnerCallFlexibleTwoWayResponder {
9406    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
9407    tx_id: u32,
9408}
9409
9410/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
9411/// if the responder is dropped without sending a response, so that the client
9412/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
9413impl std::ops::Drop for RunnerCallFlexibleTwoWayResponder {
9414    fn drop(&mut self) {
9415        self.control_handle.shutdown();
9416        // Safety: drops once, never accessed again
9417        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9418    }
9419}
9420
9421impl fidl::endpoints::Responder for RunnerCallFlexibleTwoWayResponder {
9422    type ControlHandle = RunnerControlHandle;
9423
9424    fn control_handle(&self) -> &RunnerControlHandle {
9425        &self.control_handle
9426    }
9427
9428    fn drop_without_shutdown(mut self) {
9429        // Safety: drops once, never accessed again due to mem::forget
9430        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9431        // Prevent Drop from running (which would shut down the channel)
9432        std::mem::forget(self);
9433    }
9434}
9435
9436impl RunnerCallFlexibleTwoWayResponder {
9437    /// Sends a response to the FIDL transaction.
9438    ///
9439    /// Sets the channel to shutdown if an error occurs.
9440    pub fn send(self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
9441        let _result = self.send_raw(payload);
9442        if _result.is_err() {
9443            self.control_handle.shutdown();
9444        }
9445        self.drop_without_shutdown();
9446        _result
9447    }
9448
9449    /// Similar to "send" but does not shutdown the channel if an error occurs.
9450    pub fn send_no_shutdown_on_err(
9451        self,
9452        mut payload: &EmptyResultClassification,
9453    ) -> Result<(), fidl::Error> {
9454        let _result = self.send_raw(payload);
9455        self.drop_without_shutdown();
9456        _result
9457    }
9458
9459    fn send_raw(&self, mut payload: &EmptyResultClassification) -> Result<(), fidl::Error> {
9460        self.control_handle.inner.send::<EmptyResultClassification>(
9461            payload,
9462            self.tx_id,
9463            0x411f70724876d49,
9464            fidl::encoding::DynamicFlags::empty(),
9465        )
9466    }
9467}
9468
9469#[must_use = "FIDL methods require a response to be sent"]
9470#[derive(Debug)]
9471pub struct RunnerCallFlexibleTwoWayFieldsResponder {
9472    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
9473    tx_id: u32,
9474}
9475
9476/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
9477/// if the responder is dropped without sending a response, so that the client
9478/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
9479impl std::ops::Drop for RunnerCallFlexibleTwoWayFieldsResponder {
9480    fn drop(&mut self) {
9481        self.control_handle.shutdown();
9482        // Safety: drops once, never accessed again
9483        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9484    }
9485}
9486
9487impl fidl::endpoints::Responder for RunnerCallFlexibleTwoWayFieldsResponder {
9488    type ControlHandle = RunnerControlHandle;
9489
9490    fn control_handle(&self) -> &RunnerControlHandle {
9491        &self.control_handle
9492    }
9493
9494    fn drop_without_shutdown(mut self) {
9495        // Safety: drops once, never accessed again due to mem::forget
9496        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9497        // Prevent Drop from running (which would shut down the channel)
9498        std::mem::forget(self);
9499    }
9500}
9501
9502impl RunnerCallFlexibleTwoWayFieldsResponder {
9503    /// Sends a response to the FIDL transaction.
9504    ///
9505    /// Sets the channel to shutdown if an error occurs.
9506    pub fn send(self, mut payload: &NonEmptyResultClassification) -> Result<(), fidl::Error> {
9507        let _result = self.send_raw(payload);
9508        if _result.is_err() {
9509            self.control_handle.shutdown();
9510        }
9511        self.drop_without_shutdown();
9512        _result
9513    }
9514
9515    /// Similar to "send" but does not shutdown the channel if an error occurs.
9516    pub fn send_no_shutdown_on_err(
9517        self,
9518        mut payload: &NonEmptyResultClassification,
9519    ) -> Result<(), fidl::Error> {
9520        let _result = self.send_raw(payload);
9521        self.drop_without_shutdown();
9522        _result
9523    }
9524
9525    fn send_raw(&self, mut payload: &NonEmptyResultClassification) -> Result<(), fidl::Error> {
9526        self.control_handle.inner.send::<NonEmptyResultClassification>(
9527            payload,
9528            self.tx_id,
9529            0x330996b623598eed,
9530            fidl::encoding::DynamicFlags::empty(),
9531        )
9532    }
9533}
9534
9535#[must_use = "FIDL methods require a response to be sent"]
9536#[derive(Debug)]
9537pub struct RunnerCallFlexibleTwoWayErrResponder {
9538    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
9539    tx_id: u32,
9540}
9541
9542/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
9543/// if the responder is dropped without sending a response, so that the client
9544/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
9545impl std::ops::Drop for RunnerCallFlexibleTwoWayErrResponder {
9546    fn drop(&mut self) {
9547        self.control_handle.shutdown();
9548        // Safety: drops once, never accessed again
9549        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9550    }
9551}
9552
9553impl fidl::endpoints::Responder for RunnerCallFlexibleTwoWayErrResponder {
9554    type ControlHandle = RunnerControlHandle;
9555
9556    fn control_handle(&self) -> &RunnerControlHandle {
9557        &self.control_handle
9558    }
9559
9560    fn drop_without_shutdown(mut self) {
9561        // Safety: drops once, never accessed again due to mem::forget
9562        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9563        // Prevent Drop from running (which would shut down the channel)
9564        std::mem::forget(self);
9565    }
9566}
9567
9568impl RunnerCallFlexibleTwoWayErrResponder {
9569    /// Sends a response to the FIDL transaction.
9570    ///
9571    /// Sets the channel to shutdown if an error occurs.
9572    pub fn send(self, mut payload: &EmptyResultWithErrorClassification) -> Result<(), fidl::Error> {
9573        let _result = self.send_raw(payload);
9574        if _result.is_err() {
9575            self.control_handle.shutdown();
9576        }
9577        self.drop_without_shutdown();
9578        _result
9579    }
9580
9581    /// Similar to "send" but does not shutdown the channel if an error occurs.
9582    pub fn send_no_shutdown_on_err(
9583        self,
9584        mut payload: &EmptyResultWithErrorClassification,
9585    ) -> Result<(), fidl::Error> {
9586        let _result = self.send_raw(payload);
9587        self.drop_without_shutdown();
9588        _result
9589    }
9590
9591    fn send_raw(
9592        &self,
9593        mut payload: &EmptyResultWithErrorClassification,
9594    ) -> Result<(), fidl::Error> {
9595        self.control_handle.inner.send::<EmptyResultWithErrorClassification>(
9596            payload,
9597            self.tx_id,
9598            0x5ddbf88a353a2a57,
9599            fidl::encoding::DynamicFlags::empty(),
9600        )
9601    }
9602}
9603
9604#[must_use = "FIDL methods require a response to be sent"]
9605#[derive(Debug)]
9606pub struct RunnerCallFlexibleTwoWayFieldsErrResponder {
9607    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
9608    tx_id: u32,
9609}
9610
9611/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
9612/// if the responder is dropped without sending a response, so that the client
9613/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
9614impl std::ops::Drop for RunnerCallFlexibleTwoWayFieldsErrResponder {
9615    fn drop(&mut self) {
9616        self.control_handle.shutdown();
9617        // Safety: drops once, never accessed again
9618        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9619    }
9620}
9621
9622impl fidl::endpoints::Responder for RunnerCallFlexibleTwoWayFieldsErrResponder {
9623    type ControlHandle = RunnerControlHandle;
9624
9625    fn control_handle(&self) -> &RunnerControlHandle {
9626        &self.control_handle
9627    }
9628
9629    fn drop_without_shutdown(mut self) {
9630        // Safety: drops once, never accessed again due to mem::forget
9631        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9632        // Prevent Drop from running (which would shut down the channel)
9633        std::mem::forget(self);
9634    }
9635}
9636
9637impl RunnerCallFlexibleTwoWayFieldsErrResponder {
9638    /// Sends a response to the FIDL transaction.
9639    ///
9640    /// Sets the channel to shutdown if an error occurs.
9641    pub fn send(
9642        self,
9643        mut payload: &NonEmptyResultWithErrorClassification,
9644    ) -> Result<(), fidl::Error> {
9645        let _result = self.send_raw(payload);
9646        if _result.is_err() {
9647            self.control_handle.shutdown();
9648        }
9649        self.drop_without_shutdown();
9650        _result
9651    }
9652
9653    /// Similar to "send" but does not shutdown the channel if an error occurs.
9654    pub fn send_no_shutdown_on_err(
9655        self,
9656        mut payload: &NonEmptyResultWithErrorClassification,
9657    ) -> Result<(), fidl::Error> {
9658        let _result = self.send_raw(payload);
9659        self.drop_without_shutdown();
9660        _result
9661    }
9662
9663    fn send_raw(
9664        &self,
9665        mut payload: &NonEmptyResultWithErrorClassification,
9666    ) -> Result<(), fidl::Error> {
9667        self.control_handle.inner.send::<NonEmptyResultWithErrorClassification>(
9668            payload,
9669            self.tx_id,
9670            0x7ae309383b07048e,
9671            fidl::encoding::DynamicFlags::empty(),
9672        )
9673    }
9674}
9675
9676#[must_use = "FIDL methods require a response to be sent"]
9677#[derive(Debug)]
9678pub struct RunnerReceiveClosedEventsResponder {
9679    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
9680    tx_id: u32,
9681}
9682
9683/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
9684/// if the responder is dropped without sending a response, so that the client
9685/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
9686impl std::ops::Drop for RunnerReceiveClosedEventsResponder {
9687    fn drop(&mut self) {
9688        self.control_handle.shutdown();
9689        // Safety: drops once, never accessed again
9690        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9691    }
9692}
9693
9694impl fidl::endpoints::Responder for RunnerReceiveClosedEventsResponder {
9695    type ControlHandle = RunnerControlHandle;
9696
9697    fn control_handle(&self) -> &RunnerControlHandle {
9698        &self.control_handle
9699    }
9700
9701    fn drop_without_shutdown(mut self) {
9702        // Safety: drops once, never accessed again due to mem::forget
9703        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9704        // Prevent Drop from running (which would shut down the channel)
9705        std::mem::forget(self);
9706    }
9707}
9708
9709impl RunnerReceiveClosedEventsResponder {
9710    /// Sends a response to the FIDL transaction.
9711    ///
9712    /// Sets the channel to shutdown if an error occurs.
9713    pub fn send(self) -> Result<(), fidl::Error> {
9714        let _result = self.send_raw();
9715        if _result.is_err() {
9716            self.control_handle.shutdown();
9717        }
9718        self.drop_without_shutdown();
9719        _result
9720    }
9721
9722    /// Similar to "send" but does not shutdown the channel if an error occurs.
9723    pub fn send_no_shutdown_on_err(self) -> Result<(), fidl::Error> {
9724        let _result = self.send_raw();
9725        self.drop_without_shutdown();
9726        _result
9727    }
9728
9729    fn send_raw(&self) -> Result<(), fidl::Error> {
9730        self.control_handle.inner.send::<fidl::encoding::EmptyPayload>(
9731            (),
9732            self.tx_id,
9733            0x48da834910571aeb,
9734            fidl::encoding::DynamicFlags::empty(),
9735        )
9736    }
9737}
9738
9739#[must_use = "FIDL methods require a response to be sent"]
9740#[derive(Debug)]
9741pub struct RunnerReceiveAjarEventsResponder {
9742    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
9743    tx_id: u32,
9744}
9745
9746/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
9747/// if the responder is dropped without sending a response, so that the client
9748/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
9749impl std::ops::Drop for RunnerReceiveAjarEventsResponder {
9750    fn drop(&mut self) {
9751        self.control_handle.shutdown();
9752        // Safety: drops once, never accessed again
9753        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9754    }
9755}
9756
9757impl fidl::endpoints::Responder for RunnerReceiveAjarEventsResponder {
9758    type ControlHandle = RunnerControlHandle;
9759
9760    fn control_handle(&self) -> &RunnerControlHandle {
9761        &self.control_handle
9762    }
9763
9764    fn drop_without_shutdown(mut self) {
9765        // Safety: drops once, never accessed again due to mem::forget
9766        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9767        // Prevent Drop from running (which would shut down the channel)
9768        std::mem::forget(self);
9769    }
9770}
9771
9772impl RunnerReceiveAjarEventsResponder {
9773    /// Sends a response to the FIDL transaction.
9774    ///
9775    /// Sets the channel to shutdown if an error occurs.
9776    pub fn send(self) -> Result<(), fidl::Error> {
9777        let _result = self.send_raw();
9778        if _result.is_err() {
9779            self.control_handle.shutdown();
9780        }
9781        self.drop_without_shutdown();
9782        _result
9783    }
9784
9785    /// Similar to "send" but does not shutdown the channel if an error occurs.
9786    pub fn send_no_shutdown_on_err(self) -> Result<(), fidl::Error> {
9787        let _result = self.send_raw();
9788        self.drop_without_shutdown();
9789        _result
9790    }
9791
9792    fn send_raw(&self) -> Result<(), fidl::Error> {
9793        self.control_handle.inner.send::<fidl::encoding::EmptyPayload>(
9794            (),
9795            self.tx_id,
9796            0xc5662b9a9c007a3,
9797            fidl::encoding::DynamicFlags::empty(),
9798        )
9799    }
9800}
9801
9802#[must_use = "FIDL methods require a response to be sent"]
9803#[derive(Debug)]
9804pub struct RunnerReceiveOpenEventsResponder {
9805    control_handle: std::mem::ManuallyDrop<RunnerControlHandle>,
9806    tx_id: u32,
9807}
9808
9809/// Set the the channel to be shutdown (see [`RunnerControlHandle::shutdown`])
9810/// if the responder is dropped without sending a response, so that the client
9811/// doesn't hang. To prevent this behavior, call `drop_without_shutdown`.
9812impl std::ops::Drop for RunnerReceiveOpenEventsResponder {
9813    fn drop(&mut self) {
9814        self.control_handle.shutdown();
9815        // Safety: drops once, never accessed again
9816        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9817    }
9818}
9819
9820impl fidl::endpoints::Responder for RunnerReceiveOpenEventsResponder {
9821    type ControlHandle = RunnerControlHandle;
9822
9823    fn control_handle(&self) -> &RunnerControlHandle {
9824        &self.control_handle
9825    }
9826
9827    fn drop_without_shutdown(mut self) {
9828        // Safety: drops once, never accessed again due to mem::forget
9829        unsafe { std::mem::ManuallyDrop::drop(&mut self.control_handle) };
9830        // Prevent Drop from running (which would shut down the channel)
9831        std::mem::forget(self);
9832    }
9833}
9834
9835impl RunnerReceiveOpenEventsResponder {
9836    /// Sends a response to the FIDL transaction.
9837    ///
9838    /// Sets the channel to shutdown if an error occurs.
9839    pub fn send(self) -> Result<(), fidl::Error> {
9840        let _result = self.send_raw();
9841        if _result.is_err() {
9842            self.control_handle.shutdown();
9843        }
9844        self.drop_without_shutdown();
9845        _result
9846    }
9847
9848    /// Similar to "send" but does not shutdown the channel if an error occurs.
9849    pub fn send_no_shutdown_on_err(self) -> Result<(), fidl::Error> {
9850        let _result = self.send_raw();
9851        self.drop_without_shutdown();
9852        _result
9853    }
9854
9855    fn send_raw(&self) -> Result<(), fidl::Error> {
9856        self.control_handle.inner.send::<fidl::encoding::EmptyPayload>(
9857            (),
9858            self.tx_id,
9859            0x79a7073fd18edbdf,
9860            fidl::encoding::DynamicFlags::empty(),
9861        )
9862    }
9863}
9864
9865mod internal {
9866    use super::*;
9867
9868    impl fidl::encoding::ResourceTypeMarker for RunnerCallFlexibleOneWayRequest {
9869        type Borrowed<'a> = &'a mut Self;
9870        fn take_or_borrow<'a>(
9871            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
9872        ) -> Self::Borrowed<'a> {
9873            value
9874        }
9875    }
9876
9877    unsafe impl fidl::encoding::TypeMarker for RunnerCallFlexibleOneWayRequest {
9878        type Owned = Self;
9879
9880        #[inline(always)]
9881        fn inline_align(_context: fidl::encoding::Context) -> usize {
9882            4
9883        }
9884
9885        #[inline(always)]
9886        fn inline_size(_context: fidl::encoding::Context) -> usize {
9887            4
9888        }
9889    }
9890
9891    unsafe impl
9892        fidl::encoding::Encode<
9893            RunnerCallFlexibleOneWayRequest,
9894            fidl::encoding::DefaultFuchsiaResourceDialect,
9895        > for &mut RunnerCallFlexibleOneWayRequest
9896    {
9897        #[inline]
9898        unsafe fn encode(
9899            self,
9900            encoder: &mut fidl::encoding::Encoder<
9901                '_,
9902                fidl::encoding::DefaultFuchsiaResourceDialect,
9903            >,
9904            offset: usize,
9905            _depth: fidl::encoding::Depth,
9906        ) -> fidl::Result<()> {
9907            encoder.debug_check_bounds::<RunnerCallFlexibleOneWayRequest>(offset);
9908            // Delegate to tuple encoding.
9909            fidl::encoding::Encode::<RunnerCallFlexibleOneWayRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
9910                (
9911                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
9912                ),
9913                encoder, offset, _depth
9914            )
9915        }
9916    }
9917    unsafe impl<
9918            T0: fidl::encoding::Encode<
9919                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
9920                fidl::encoding::DefaultFuchsiaResourceDialect,
9921            >,
9922        >
9923        fidl::encoding::Encode<
9924            RunnerCallFlexibleOneWayRequest,
9925            fidl::encoding::DefaultFuchsiaResourceDialect,
9926        > for (T0,)
9927    {
9928        #[inline]
9929        unsafe fn encode(
9930            self,
9931            encoder: &mut fidl::encoding::Encoder<
9932                '_,
9933                fidl::encoding::DefaultFuchsiaResourceDialect,
9934            >,
9935            offset: usize,
9936            depth: fidl::encoding::Depth,
9937        ) -> fidl::Result<()> {
9938            encoder.debug_check_bounds::<RunnerCallFlexibleOneWayRequest>(offset);
9939            // Zero out padding regions. There's no need to apply masks
9940            // because the unmasked parts will be overwritten by fields.
9941            // Write the fields.
9942            self.0.encode(encoder, offset + 0, depth)?;
9943            Ok(())
9944        }
9945    }
9946
9947    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
9948        for RunnerCallFlexibleOneWayRequest
9949    {
9950        #[inline(always)]
9951        fn new_empty() -> Self {
9952            Self {
9953                target: fidl::new_empty!(
9954                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
9955                    fidl::encoding::DefaultFuchsiaResourceDialect
9956                ),
9957            }
9958        }
9959
9960        #[inline]
9961        unsafe fn decode(
9962            &mut self,
9963            decoder: &mut fidl::encoding::Decoder<
9964                '_,
9965                fidl::encoding::DefaultFuchsiaResourceDialect,
9966            >,
9967            offset: usize,
9968            _depth: fidl::encoding::Depth,
9969        ) -> fidl::Result<()> {
9970            decoder.debug_check_bounds::<Self>(offset);
9971            // Verify that padding bytes are zero.
9972            fidl::decode!(
9973                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
9974                fidl::encoding::DefaultFuchsiaResourceDialect,
9975                &mut self.target,
9976                decoder,
9977                offset + 0,
9978                _depth
9979            )?;
9980            Ok(())
9981        }
9982    }
9983
9984    impl fidl::encoding::ResourceTypeMarker for RunnerCallFlexibleTwoWayErrRequest {
9985        type Borrowed<'a> = &'a mut Self;
9986        fn take_or_borrow<'a>(
9987            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
9988        ) -> Self::Borrowed<'a> {
9989            value
9990        }
9991    }
9992
9993    unsafe impl fidl::encoding::TypeMarker for RunnerCallFlexibleTwoWayErrRequest {
9994        type Owned = Self;
9995
9996        #[inline(always)]
9997        fn inline_align(_context: fidl::encoding::Context) -> usize {
9998            4
9999        }
10000
10001        #[inline(always)]
10002        fn inline_size(_context: fidl::encoding::Context) -> usize {
10003            4
10004        }
10005    }
10006
10007    unsafe impl
10008        fidl::encoding::Encode<
10009            RunnerCallFlexibleTwoWayErrRequest,
10010            fidl::encoding::DefaultFuchsiaResourceDialect,
10011        > for &mut RunnerCallFlexibleTwoWayErrRequest
10012    {
10013        #[inline]
10014        unsafe fn encode(
10015            self,
10016            encoder: &mut fidl::encoding::Encoder<
10017                '_,
10018                fidl::encoding::DefaultFuchsiaResourceDialect,
10019            >,
10020            offset: usize,
10021            _depth: fidl::encoding::Depth,
10022        ) -> fidl::Result<()> {
10023            encoder.debug_check_bounds::<RunnerCallFlexibleTwoWayErrRequest>(offset);
10024            // Delegate to tuple encoding.
10025            fidl::encoding::Encode::<RunnerCallFlexibleTwoWayErrRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
10026                (
10027                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
10028                ),
10029                encoder, offset, _depth
10030            )
10031        }
10032    }
10033    unsafe impl<
10034            T0: fidl::encoding::Encode<
10035                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
10036                fidl::encoding::DefaultFuchsiaResourceDialect,
10037            >,
10038        >
10039        fidl::encoding::Encode<
10040            RunnerCallFlexibleTwoWayErrRequest,
10041            fidl::encoding::DefaultFuchsiaResourceDialect,
10042        > for (T0,)
10043    {
10044        #[inline]
10045        unsafe fn encode(
10046            self,
10047            encoder: &mut fidl::encoding::Encoder<
10048                '_,
10049                fidl::encoding::DefaultFuchsiaResourceDialect,
10050            >,
10051            offset: usize,
10052            depth: fidl::encoding::Depth,
10053        ) -> fidl::Result<()> {
10054            encoder.debug_check_bounds::<RunnerCallFlexibleTwoWayErrRequest>(offset);
10055            // Zero out padding regions. There's no need to apply masks
10056            // because the unmasked parts will be overwritten by fields.
10057            // Write the fields.
10058            self.0.encode(encoder, offset + 0, depth)?;
10059            Ok(())
10060        }
10061    }
10062
10063    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
10064        for RunnerCallFlexibleTwoWayErrRequest
10065    {
10066        #[inline(always)]
10067        fn new_empty() -> Self {
10068            Self {
10069                target: fidl::new_empty!(
10070                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
10071                    fidl::encoding::DefaultFuchsiaResourceDialect
10072                ),
10073            }
10074        }
10075
10076        #[inline]
10077        unsafe fn decode(
10078            &mut self,
10079            decoder: &mut fidl::encoding::Decoder<
10080                '_,
10081                fidl::encoding::DefaultFuchsiaResourceDialect,
10082            >,
10083            offset: usize,
10084            _depth: fidl::encoding::Depth,
10085        ) -> fidl::Result<()> {
10086            decoder.debug_check_bounds::<Self>(offset);
10087            // Verify that padding bytes are zero.
10088            fidl::decode!(
10089                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
10090                fidl::encoding::DefaultFuchsiaResourceDialect,
10091                &mut self.target,
10092                decoder,
10093                offset + 0,
10094                _depth
10095            )?;
10096            Ok(())
10097        }
10098    }
10099
10100    impl fidl::encoding::ResourceTypeMarker for RunnerCallFlexibleTwoWayFieldsErrRequest {
10101        type Borrowed<'a> = &'a mut Self;
10102        fn take_or_borrow<'a>(
10103            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
10104        ) -> Self::Borrowed<'a> {
10105            value
10106        }
10107    }
10108
10109    unsafe impl fidl::encoding::TypeMarker for RunnerCallFlexibleTwoWayFieldsErrRequest {
10110        type Owned = Self;
10111
10112        #[inline(always)]
10113        fn inline_align(_context: fidl::encoding::Context) -> usize {
10114            4
10115        }
10116
10117        #[inline(always)]
10118        fn inline_size(_context: fidl::encoding::Context) -> usize {
10119            4
10120        }
10121    }
10122
10123    unsafe impl
10124        fidl::encoding::Encode<
10125            RunnerCallFlexibleTwoWayFieldsErrRequest,
10126            fidl::encoding::DefaultFuchsiaResourceDialect,
10127        > for &mut RunnerCallFlexibleTwoWayFieldsErrRequest
10128    {
10129        #[inline]
10130        unsafe fn encode(
10131            self,
10132            encoder: &mut fidl::encoding::Encoder<
10133                '_,
10134                fidl::encoding::DefaultFuchsiaResourceDialect,
10135            >,
10136            offset: usize,
10137            _depth: fidl::encoding::Depth,
10138        ) -> fidl::Result<()> {
10139            encoder.debug_check_bounds::<RunnerCallFlexibleTwoWayFieldsErrRequest>(offset);
10140            // Delegate to tuple encoding.
10141            fidl::encoding::Encode::<RunnerCallFlexibleTwoWayFieldsErrRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
10142                (
10143                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
10144                ),
10145                encoder, offset, _depth
10146            )
10147        }
10148    }
10149    unsafe impl<
10150            T0: fidl::encoding::Encode<
10151                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
10152                fidl::encoding::DefaultFuchsiaResourceDialect,
10153            >,
10154        >
10155        fidl::encoding::Encode<
10156            RunnerCallFlexibleTwoWayFieldsErrRequest,
10157            fidl::encoding::DefaultFuchsiaResourceDialect,
10158        > for (T0,)
10159    {
10160        #[inline]
10161        unsafe fn encode(
10162            self,
10163            encoder: &mut fidl::encoding::Encoder<
10164                '_,
10165                fidl::encoding::DefaultFuchsiaResourceDialect,
10166            >,
10167            offset: usize,
10168            depth: fidl::encoding::Depth,
10169        ) -> fidl::Result<()> {
10170            encoder.debug_check_bounds::<RunnerCallFlexibleTwoWayFieldsErrRequest>(offset);
10171            // Zero out padding regions. There's no need to apply masks
10172            // because the unmasked parts will be overwritten by fields.
10173            // Write the fields.
10174            self.0.encode(encoder, offset + 0, depth)?;
10175            Ok(())
10176        }
10177    }
10178
10179    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
10180        for RunnerCallFlexibleTwoWayFieldsErrRequest
10181    {
10182        #[inline(always)]
10183        fn new_empty() -> Self {
10184            Self {
10185                target: fidl::new_empty!(
10186                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
10187                    fidl::encoding::DefaultFuchsiaResourceDialect
10188                ),
10189            }
10190        }
10191
10192        #[inline]
10193        unsafe fn decode(
10194            &mut self,
10195            decoder: &mut fidl::encoding::Decoder<
10196                '_,
10197                fidl::encoding::DefaultFuchsiaResourceDialect,
10198            >,
10199            offset: usize,
10200            _depth: fidl::encoding::Depth,
10201        ) -> fidl::Result<()> {
10202            decoder.debug_check_bounds::<Self>(offset);
10203            // Verify that padding bytes are zero.
10204            fidl::decode!(
10205                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
10206                fidl::encoding::DefaultFuchsiaResourceDialect,
10207                &mut self.target,
10208                decoder,
10209                offset + 0,
10210                _depth
10211            )?;
10212            Ok(())
10213        }
10214    }
10215
10216    impl fidl::encoding::ResourceTypeMarker for RunnerCallFlexibleTwoWayFieldsRequest {
10217        type Borrowed<'a> = &'a mut Self;
10218        fn take_or_borrow<'a>(
10219            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
10220        ) -> Self::Borrowed<'a> {
10221            value
10222        }
10223    }
10224
10225    unsafe impl fidl::encoding::TypeMarker for RunnerCallFlexibleTwoWayFieldsRequest {
10226        type Owned = Self;
10227
10228        #[inline(always)]
10229        fn inline_align(_context: fidl::encoding::Context) -> usize {
10230            4
10231        }
10232
10233        #[inline(always)]
10234        fn inline_size(_context: fidl::encoding::Context) -> usize {
10235            4
10236        }
10237    }
10238
10239    unsafe impl
10240        fidl::encoding::Encode<
10241            RunnerCallFlexibleTwoWayFieldsRequest,
10242            fidl::encoding::DefaultFuchsiaResourceDialect,
10243        > for &mut RunnerCallFlexibleTwoWayFieldsRequest
10244    {
10245        #[inline]
10246        unsafe fn encode(
10247            self,
10248            encoder: &mut fidl::encoding::Encoder<
10249                '_,
10250                fidl::encoding::DefaultFuchsiaResourceDialect,
10251            >,
10252            offset: usize,
10253            _depth: fidl::encoding::Depth,
10254        ) -> fidl::Result<()> {
10255            encoder.debug_check_bounds::<RunnerCallFlexibleTwoWayFieldsRequest>(offset);
10256            // Delegate to tuple encoding.
10257            fidl::encoding::Encode::<RunnerCallFlexibleTwoWayFieldsRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
10258                (
10259                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
10260                ),
10261                encoder, offset, _depth
10262            )
10263        }
10264    }
10265    unsafe impl<
10266            T0: fidl::encoding::Encode<
10267                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
10268                fidl::encoding::DefaultFuchsiaResourceDialect,
10269            >,
10270        >
10271        fidl::encoding::Encode<
10272            RunnerCallFlexibleTwoWayFieldsRequest,
10273            fidl::encoding::DefaultFuchsiaResourceDialect,
10274        > for (T0,)
10275    {
10276        #[inline]
10277        unsafe fn encode(
10278            self,
10279            encoder: &mut fidl::encoding::Encoder<
10280                '_,
10281                fidl::encoding::DefaultFuchsiaResourceDialect,
10282            >,
10283            offset: usize,
10284            depth: fidl::encoding::Depth,
10285        ) -> fidl::Result<()> {
10286            encoder.debug_check_bounds::<RunnerCallFlexibleTwoWayFieldsRequest>(offset);
10287            // Zero out padding regions. There's no need to apply masks
10288            // because the unmasked parts will be overwritten by fields.
10289            // Write the fields.
10290            self.0.encode(encoder, offset + 0, depth)?;
10291            Ok(())
10292        }
10293    }
10294
10295    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
10296        for RunnerCallFlexibleTwoWayFieldsRequest
10297    {
10298        #[inline(always)]
10299        fn new_empty() -> Self {
10300            Self {
10301                target: fidl::new_empty!(
10302                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
10303                    fidl::encoding::DefaultFuchsiaResourceDialect
10304                ),
10305            }
10306        }
10307
10308        #[inline]
10309        unsafe fn decode(
10310            &mut self,
10311            decoder: &mut fidl::encoding::Decoder<
10312                '_,
10313                fidl::encoding::DefaultFuchsiaResourceDialect,
10314            >,
10315            offset: usize,
10316            _depth: fidl::encoding::Depth,
10317        ) -> fidl::Result<()> {
10318            decoder.debug_check_bounds::<Self>(offset);
10319            // Verify that padding bytes are zero.
10320            fidl::decode!(
10321                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
10322                fidl::encoding::DefaultFuchsiaResourceDialect,
10323                &mut self.target,
10324                decoder,
10325                offset + 0,
10326                _depth
10327            )?;
10328            Ok(())
10329        }
10330    }
10331
10332    impl fidl::encoding::ResourceTypeMarker for RunnerCallFlexibleTwoWayRequest {
10333        type Borrowed<'a> = &'a mut Self;
10334        fn take_or_borrow<'a>(
10335            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
10336        ) -> Self::Borrowed<'a> {
10337            value
10338        }
10339    }
10340
10341    unsafe impl fidl::encoding::TypeMarker for RunnerCallFlexibleTwoWayRequest {
10342        type Owned = Self;
10343
10344        #[inline(always)]
10345        fn inline_align(_context: fidl::encoding::Context) -> usize {
10346            4
10347        }
10348
10349        #[inline(always)]
10350        fn inline_size(_context: fidl::encoding::Context) -> usize {
10351            4
10352        }
10353    }
10354
10355    unsafe impl
10356        fidl::encoding::Encode<
10357            RunnerCallFlexibleTwoWayRequest,
10358            fidl::encoding::DefaultFuchsiaResourceDialect,
10359        > for &mut RunnerCallFlexibleTwoWayRequest
10360    {
10361        #[inline]
10362        unsafe fn encode(
10363            self,
10364            encoder: &mut fidl::encoding::Encoder<
10365                '_,
10366                fidl::encoding::DefaultFuchsiaResourceDialect,
10367            >,
10368            offset: usize,
10369            _depth: fidl::encoding::Depth,
10370        ) -> fidl::Result<()> {
10371            encoder.debug_check_bounds::<RunnerCallFlexibleTwoWayRequest>(offset);
10372            // Delegate to tuple encoding.
10373            fidl::encoding::Encode::<RunnerCallFlexibleTwoWayRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
10374                (
10375                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
10376                ),
10377                encoder, offset, _depth
10378            )
10379        }
10380    }
10381    unsafe impl<
10382            T0: fidl::encoding::Encode<
10383                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
10384                fidl::encoding::DefaultFuchsiaResourceDialect,
10385            >,
10386        >
10387        fidl::encoding::Encode<
10388            RunnerCallFlexibleTwoWayRequest,
10389            fidl::encoding::DefaultFuchsiaResourceDialect,
10390        > for (T0,)
10391    {
10392        #[inline]
10393        unsafe fn encode(
10394            self,
10395            encoder: &mut fidl::encoding::Encoder<
10396                '_,
10397                fidl::encoding::DefaultFuchsiaResourceDialect,
10398            >,
10399            offset: usize,
10400            depth: fidl::encoding::Depth,
10401        ) -> fidl::Result<()> {
10402            encoder.debug_check_bounds::<RunnerCallFlexibleTwoWayRequest>(offset);
10403            // Zero out padding regions. There's no need to apply masks
10404            // because the unmasked parts will be overwritten by fields.
10405            // Write the fields.
10406            self.0.encode(encoder, offset + 0, depth)?;
10407            Ok(())
10408        }
10409    }
10410
10411    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
10412        for RunnerCallFlexibleTwoWayRequest
10413    {
10414        #[inline(always)]
10415        fn new_empty() -> Self {
10416            Self {
10417                target: fidl::new_empty!(
10418                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
10419                    fidl::encoding::DefaultFuchsiaResourceDialect
10420                ),
10421            }
10422        }
10423
10424        #[inline]
10425        unsafe fn decode(
10426            &mut self,
10427            decoder: &mut fidl::encoding::Decoder<
10428                '_,
10429                fidl::encoding::DefaultFuchsiaResourceDialect,
10430            >,
10431            offset: usize,
10432            _depth: fidl::encoding::Depth,
10433        ) -> fidl::Result<()> {
10434            decoder.debug_check_bounds::<Self>(offset);
10435            // Verify that padding bytes are zero.
10436            fidl::decode!(
10437                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
10438                fidl::encoding::DefaultFuchsiaResourceDialect,
10439                &mut self.target,
10440                decoder,
10441                offset + 0,
10442                _depth
10443            )?;
10444            Ok(())
10445        }
10446    }
10447
10448    impl fidl::encoding::ResourceTypeMarker for RunnerCallOneWayNoRequestRequest {
10449        type Borrowed<'a> = &'a mut Self;
10450        fn take_or_borrow<'a>(
10451            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
10452        ) -> Self::Borrowed<'a> {
10453            value
10454        }
10455    }
10456
10457    unsafe impl fidl::encoding::TypeMarker for RunnerCallOneWayNoRequestRequest {
10458        type Owned = Self;
10459
10460        #[inline(always)]
10461        fn inline_align(_context: fidl::encoding::Context) -> usize {
10462            4
10463        }
10464
10465        #[inline(always)]
10466        fn inline_size(_context: fidl::encoding::Context) -> usize {
10467            4
10468        }
10469    }
10470
10471    unsafe impl
10472        fidl::encoding::Encode<
10473            RunnerCallOneWayNoRequestRequest,
10474            fidl::encoding::DefaultFuchsiaResourceDialect,
10475        > for &mut RunnerCallOneWayNoRequestRequest
10476    {
10477        #[inline]
10478        unsafe fn encode(
10479            self,
10480            encoder: &mut fidl::encoding::Encoder<
10481                '_,
10482                fidl::encoding::DefaultFuchsiaResourceDialect,
10483            >,
10484            offset: usize,
10485            _depth: fidl::encoding::Depth,
10486        ) -> fidl::Result<()> {
10487            encoder.debug_check_bounds::<RunnerCallOneWayNoRequestRequest>(offset);
10488            // Delegate to tuple encoding.
10489            fidl::encoding::Encode::<RunnerCallOneWayNoRequestRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
10490                (
10491                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
10492                ),
10493                encoder, offset, _depth
10494            )
10495        }
10496    }
10497    unsafe impl<
10498            T0: fidl::encoding::Encode<
10499                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
10500                fidl::encoding::DefaultFuchsiaResourceDialect,
10501            >,
10502        >
10503        fidl::encoding::Encode<
10504            RunnerCallOneWayNoRequestRequest,
10505            fidl::encoding::DefaultFuchsiaResourceDialect,
10506        > for (T0,)
10507    {
10508        #[inline]
10509        unsafe fn encode(
10510            self,
10511            encoder: &mut fidl::encoding::Encoder<
10512                '_,
10513                fidl::encoding::DefaultFuchsiaResourceDialect,
10514            >,
10515            offset: usize,
10516            depth: fidl::encoding::Depth,
10517        ) -> fidl::Result<()> {
10518            encoder.debug_check_bounds::<RunnerCallOneWayNoRequestRequest>(offset);
10519            // Zero out padding regions. There's no need to apply masks
10520            // because the unmasked parts will be overwritten by fields.
10521            // Write the fields.
10522            self.0.encode(encoder, offset + 0, depth)?;
10523            Ok(())
10524        }
10525    }
10526
10527    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
10528        for RunnerCallOneWayNoRequestRequest
10529    {
10530        #[inline(always)]
10531        fn new_empty() -> Self {
10532            Self {
10533                target: fidl::new_empty!(
10534                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
10535                    fidl::encoding::DefaultFuchsiaResourceDialect
10536                ),
10537            }
10538        }
10539
10540        #[inline]
10541        unsafe fn decode(
10542            &mut self,
10543            decoder: &mut fidl::encoding::Decoder<
10544                '_,
10545                fidl::encoding::DefaultFuchsiaResourceDialect,
10546            >,
10547            offset: usize,
10548            _depth: fidl::encoding::Depth,
10549        ) -> fidl::Result<()> {
10550            decoder.debug_check_bounds::<Self>(offset);
10551            // Verify that padding bytes are zero.
10552            fidl::decode!(
10553                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
10554                fidl::encoding::DefaultFuchsiaResourceDialect,
10555                &mut self.target,
10556                decoder,
10557                offset + 0,
10558                _depth
10559            )?;
10560            Ok(())
10561        }
10562    }
10563
10564    impl fidl::encoding::ResourceTypeMarker for RunnerCallOneWayStructRequestRequest {
10565        type Borrowed<'a> = &'a mut Self;
10566        fn take_or_borrow<'a>(
10567            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
10568        ) -> Self::Borrowed<'a> {
10569            value
10570        }
10571    }
10572
10573    unsafe impl fidl::encoding::TypeMarker for RunnerCallOneWayStructRequestRequest {
10574        type Owned = Self;
10575
10576        #[inline(always)]
10577        fn inline_align(_context: fidl::encoding::Context) -> usize {
10578            4
10579        }
10580
10581        #[inline(always)]
10582        fn inline_size(_context: fidl::encoding::Context) -> usize {
10583            8
10584        }
10585    }
10586
10587    unsafe impl
10588        fidl::encoding::Encode<
10589            RunnerCallOneWayStructRequestRequest,
10590            fidl::encoding::DefaultFuchsiaResourceDialect,
10591        > for &mut RunnerCallOneWayStructRequestRequest
10592    {
10593        #[inline]
10594        unsafe fn encode(
10595            self,
10596            encoder: &mut fidl::encoding::Encoder<
10597                '_,
10598                fidl::encoding::DefaultFuchsiaResourceDialect,
10599            >,
10600            offset: usize,
10601            _depth: fidl::encoding::Depth,
10602        ) -> fidl::Result<()> {
10603            encoder.debug_check_bounds::<RunnerCallOneWayStructRequestRequest>(offset);
10604            // Delegate to tuple encoding.
10605            fidl::encoding::Encode::<RunnerCallOneWayStructRequestRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
10606                (
10607                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
10608                    <NonEmptyPayload as fidl::encoding::ValueTypeMarker>::borrow(&self.request),
10609                ),
10610                encoder, offset, _depth
10611            )
10612        }
10613    }
10614    unsafe impl<
10615            T0: fidl::encoding::Encode<
10616                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
10617                fidl::encoding::DefaultFuchsiaResourceDialect,
10618            >,
10619            T1: fidl::encoding::Encode<NonEmptyPayload, fidl::encoding::DefaultFuchsiaResourceDialect>,
10620        >
10621        fidl::encoding::Encode<
10622            RunnerCallOneWayStructRequestRequest,
10623            fidl::encoding::DefaultFuchsiaResourceDialect,
10624        > for (T0, T1)
10625    {
10626        #[inline]
10627        unsafe fn encode(
10628            self,
10629            encoder: &mut fidl::encoding::Encoder<
10630                '_,
10631                fidl::encoding::DefaultFuchsiaResourceDialect,
10632            >,
10633            offset: usize,
10634            depth: fidl::encoding::Depth,
10635        ) -> fidl::Result<()> {
10636            encoder.debug_check_bounds::<RunnerCallOneWayStructRequestRequest>(offset);
10637            // Zero out padding regions. There's no need to apply masks
10638            // because the unmasked parts will be overwritten by fields.
10639            // Write the fields.
10640            self.0.encode(encoder, offset + 0, depth)?;
10641            self.1.encode(encoder, offset + 4, depth)?;
10642            Ok(())
10643        }
10644    }
10645
10646    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
10647        for RunnerCallOneWayStructRequestRequest
10648    {
10649        #[inline(always)]
10650        fn new_empty() -> Self {
10651            Self {
10652                target: fidl::new_empty!(
10653                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
10654                    fidl::encoding::DefaultFuchsiaResourceDialect
10655                ),
10656                request: fidl::new_empty!(
10657                    NonEmptyPayload,
10658                    fidl::encoding::DefaultFuchsiaResourceDialect
10659                ),
10660            }
10661        }
10662
10663        #[inline]
10664        unsafe fn decode(
10665            &mut self,
10666            decoder: &mut fidl::encoding::Decoder<
10667                '_,
10668                fidl::encoding::DefaultFuchsiaResourceDialect,
10669            >,
10670            offset: usize,
10671            _depth: fidl::encoding::Depth,
10672        ) -> fidl::Result<()> {
10673            decoder.debug_check_bounds::<Self>(offset);
10674            // Verify that padding bytes are zero.
10675            fidl::decode!(
10676                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
10677                fidl::encoding::DefaultFuchsiaResourceDialect,
10678                &mut self.target,
10679                decoder,
10680                offset + 0,
10681                _depth
10682            )?;
10683            fidl::decode!(
10684                NonEmptyPayload,
10685                fidl::encoding::DefaultFuchsiaResourceDialect,
10686                &mut self.request,
10687                decoder,
10688                offset + 4,
10689                _depth
10690            )?;
10691            Ok(())
10692        }
10693    }
10694
10695    impl fidl::encoding::ResourceTypeMarker for RunnerCallOneWayTableRequestRequest {
10696        type Borrowed<'a> = &'a mut Self;
10697        fn take_or_borrow<'a>(
10698            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
10699        ) -> Self::Borrowed<'a> {
10700            value
10701        }
10702    }
10703
10704    unsafe impl fidl::encoding::TypeMarker for RunnerCallOneWayTableRequestRequest {
10705        type Owned = Self;
10706
10707        #[inline(always)]
10708        fn inline_align(_context: fidl::encoding::Context) -> usize {
10709            8
10710        }
10711
10712        #[inline(always)]
10713        fn inline_size(_context: fidl::encoding::Context) -> usize {
10714            24
10715        }
10716    }
10717
10718    unsafe impl
10719        fidl::encoding::Encode<
10720            RunnerCallOneWayTableRequestRequest,
10721            fidl::encoding::DefaultFuchsiaResourceDialect,
10722        > for &mut RunnerCallOneWayTableRequestRequest
10723    {
10724        #[inline]
10725        unsafe fn encode(
10726            self,
10727            encoder: &mut fidl::encoding::Encoder<
10728                '_,
10729                fidl::encoding::DefaultFuchsiaResourceDialect,
10730            >,
10731            offset: usize,
10732            _depth: fidl::encoding::Depth,
10733        ) -> fidl::Result<()> {
10734            encoder.debug_check_bounds::<RunnerCallOneWayTableRequestRequest>(offset);
10735            // Delegate to tuple encoding.
10736            fidl::encoding::Encode::<RunnerCallOneWayTableRequestRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
10737                (
10738                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
10739                    <TablePayload as fidl::encoding::ValueTypeMarker>::borrow(&self.request),
10740                ),
10741                encoder, offset, _depth
10742            )
10743        }
10744    }
10745    unsafe impl<
10746            T0: fidl::encoding::Encode<
10747                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
10748                fidl::encoding::DefaultFuchsiaResourceDialect,
10749            >,
10750            T1: fidl::encoding::Encode<TablePayload, fidl::encoding::DefaultFuchsiaResourceDialect>,
10751        >
10752        fidl::encoding::Encode<
10753            RunnerCallOneWayTableRequestRequest,
10754            fidl::encoding::DefaultFuchsiaResourceDialect,
10755        > for (T0, T1)
10756    {
10757        #[inline]
10758        unsafe fn encode(
10759            self,
10760            encoder: &mut fidl::encoding::Encoder<
10761                '_,
10762                fidl::encoding::DefaultFuchsiaResourceDialect,
10763            >,
10764            offset: usize,
10765            depth: fidl::encoding::Depth,
10766        ) -> fidl::Result<()> {
10767            encoder.debug_check_bounds::<RunnerCallOneWayTableRequestRequest>(offset);
10768            // Zero out padding regions. There's no need to apply masks
10769            // because the unmasked parts will be overwritten by fields.
10770            unsafe {
10771                let ptr = encoder.buf.as_mut_ptr().add(offset).offset(0);
10772                (ptr as *mut u64).write_unaligned(0);
10773            }
10774            // Write the fields.
10775            self.0.encode(encoder, offset + 0, depth)?;
10776            self.1.encode(encoder, offset + 8, depth)?;
10777            Ok(())
10778        }
10779    }
10780
10781    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
10782        for RunnerCallOneWayTableRequestRequest
10783    {
10784        #[inline(always)]
10785        fn new_empty() -> Self {
10786            Self {
10787                target: fidl::new_empty!(
10788                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
10789                    fidl::encoding::DefaultFuchsiaResourceDialect
10790                ),
10791                request: fidl::new_empty!(
10792                    TablePayload,
10793                    fidl::encoding::DefaultFuchsiaResourceDialect
10794                ),
10795            }
10796        }
10797
10798        #[inline]
10799        unsafe fn decode(
10800            &mut self,
10801            decoder: &mut fidl::encoding::Decoder<
10802                '_,
10803                fidl::encoding::DefaultFuchsiaResourceDialect,
10804            >,
10805            offset: usize,
10806            _depth: fidl::encoding::Depth,
10807        ) -> fidl::Result<()> {
10808            decoder.debug_check_bounds::<Self>(offset);
10809            // Verify that padding bytes are zero.
10810            let ptr = unsafe { decoder.buf.as_ptr().add(offset).offset(0) };
10811            let padval = unsafe { (ptr as *const u64).read_unaligned() };
10812            let mask = 0xffffffff00000000u64;
10813            let maskedval = padval & mask;
10814            if maskedval != 0 {
10815                return Err(fidl::Error::NonZeroPadding {
10816                    padding_start: offset + 0 + ((mask as u64).trailing_zeros() / 8) as usize,
10817                });
10818            }
10819            fidl::decode!(
10820                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
10821                fidl::encoding::DefaultFuchsiaResourceDialect,
10822                &mut self.target,
10823                decoder,
10824                offset + 0,
10825                _depth
10826            )?;
10827            fidl::decode!(
10828                TablePayload,
10829                fidl::encoding::DefaultFuchsiaResourceDialect,
10830                &mut self.request,
10831                decoder,
10832                offset + 8,
10833                _depth
10834            )?;
10835            Ok(())
10836        }
10837    }
10838
10839    impl fidl::encoding::ResourceTypeMarker for RunnerCallOneWayUnionRequestRequest {
10840        type Borrowed<'a> = &'a mut Self;
10841        fn take_or_borrow<'a>(
10842            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
10843        ) -> Self::Borrowed<'a> {
10844            value
10845        }
10846    }
10847
10848    unsafe impl fidl::encoding::TypeMarker for RunnerCallOneWayUnionRequestRequest {
10849        type Owned = Self;
10850
10851        #[inline(always)]
10852        fn inline_align(_context: fidl::encoding::Context) -> usize {
10853            8
10854        }
10855
10856        #[inline(always)]
10857        fn inline_size(_context: fidl::encoding::Context) -> usize {
10858            24
10859        }
10860    }
10861
10862    unsafe impl
10863        fidl::encoding::Encode<
10864            RunnerCallOneWayUnionRequestRequest,
10865            fidl::encoding::DefaultFuchsiaResourceDialect,
10866        > for &mut RunnerCallOneWayUnionRequestRequest
10867    {
10868        #[inline]
10869        unsafe fn encode(
10870            self,
10871            encoder: &mut fidl::encoding::Encoder<
10872                '_,
10873                fidl::encoding::DefaultFuchsiaResourceDialect,
10874            >,
10875            offset: usize,
10876            _depth: fidl::encoding::Depth,
10877        ) -> fidl::Result<()> {
10878            encoder.debug_check_bounds::<RunnerCallOneWayUnionRequestRequest>(offset);
10879            // Delegate to tuple encoding.
10880            fidl::encoding::Encode::<RunnerCallOneWayUnionRequestRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
10881                (
10882                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
10883                    <UnionPayload as fidl::encoding::ValueTypeMarker>::borrow(&self.request),
10884                ),
10885                encoder, offset, _depth
10886            )
10887        }
10888    }
10889    unsafe impl<
10890            T0: fidl::encoding::Encode<
10891                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
10892                fidl::encoding::DefaultFuchsiaResourceDialect,
10893            >,
10894            T1: fidl::encoding::Encode<UnionPayload, fidl::encoding::DefaultFuchsiaResourceDialect>,
10895        >
10896        fidl::encoding::Encode<
10897            RunnerCallOneWayUnionRequestRequest,
10898            fidl::encoding::DefaultFuchsiaResourceDialect,
10899        > for (T0, T1)
10900    {
10901        #[inline]
10902        unsafe fn encode(
10903            self,
10904            encoder: &mut fidl::encoding::Encoder<
10905                '_,
10906                fidl::encoding::DefaultFuchsiaResourceDialect,
10907            >,
10908            offset: usize,
10909            depth: fidl::encoding::Depth,
10910        ) -> fidl::Result<()> {
10911            encoder.debug_check_bounds::<RunnerCallOneWayUnionRequestRequest>(offset);
10912            // Zero out padding regions. There's no need to apply masks
10913            // because the unmasked parts will be overwritten by fields.
10914            unsafe {
10915                let ptr = encoder.buf.as_mut_ptr().add(offset).offset(0);
10916                (ptr as *mut u64).write_unaligned(0);
10917            }
10918            // Write the fields.
10919            self.0.encode(encoder, offset + 0, depth)?;
10920            self.1.encode(encoder, offset + 8, depth)?;
10921            Ok(())
10922        }
10923    }
10924
10925    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
10926        for RunnerCallOneWayUnionRequestRequest
10927    {
10928        #[inline(always)]
10929        fn new_empty() -> Self {
10930            Self {
10931                target: fidl::new_empty!(
10932                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
10933                    fidl::encoding::DefaultFuchsiaResourceDialect
10934                ),
10935                request: fidl::new_empty!(
10936                    UnionPayload,
10937                    fidl::encoding::DefaultFuchsiaResourceDialect
10938                ),
10939            }
10940        }
10941
10942        #[inline]
10943        unsafe fn decode(
10944            &mut self,
10945            decoder: &mut fidl::encoding::Decoder<
10946                '_,
10947                fidl::encoding::DefaultFuchsiaResourceDialect,
10948            >,
10949            offset: usize,
10950            _depth: fidl::encoding::Depth,
10951        ) -> fidl::Result<()> {
10952            decoder.debug_check_bounds::<Self>(offset);
10953            // Verify that padding bytes are zero.
10954            let ptr = unsafe { decoder.buf.as_ptr().add(offset).offset(0) };
10955            let padval = unsafe { (ptr as *const u64).read_unaligned() };
10956            let mask = 0xffffffff00000000u64;
10957            let maskedval = padval & mask;
10958            if maskedval != 0 {
10959                return Err(fidl::Error::NonZeroPadding {
10960                    padding_start: offset + 0 + ((mask as u64).trailing_zeros() / 8) as usize,
10961                });
10962            }
10963            fidl::decode!(
10964                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
10965                fidl::encoding::DefaultFuchsiaResourceDialect,
10966                &mut self.target,
10967                decoder,
10968                offset + 0,
10969                _depth
10970            )?;
10971            fidl::decode!(
10972                UnionPayload,
10973                fidl::encoding::DefaultFuchsiaResourceDialect,
10974                &mut self.request,
10975                decoder,
10976                offset + 8,
10977                _depth
10978            )?;
10979            Ok(())
10980        }
10981    }
10982
10983    impl fidl::encoding::ResourceTypeMarker for RunnerCallStrictOneWayRequest {
10984        type Borrowed<'a> = &'a mut Self;
10985        fn take_or_borrow<'a>(
10986            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
10987        ) -> Self::Borrowed<'a> {
10988            value
10989        }
10990    }
10991
10992    unsafe impl fidl::encoding::TypeMarker for RunnerCallStrictOneWayRequest {
10993        type Owned = Self;
10994
10995        #[inline(always)]
10996        fn inline_align(_context: fidl::encoding::Context) -> usize {
10997            4
10998        }
10999
11000        #[inline(always)]
11001        fn inline_size(_context: fidl::encoding::Context) -> usize {
11002            4
11003        }
11004    }
11005
11006    unsafe impl
11007        fidl::encoding::Encode<
11008            RunnerCallStrictOneWayRequest,
11009            fidl::encoding::DefaultFuchsiaResourceDialect,
11010        > for &mut RunnerCallStrictOneWayRequest
11011    {
11012        #[inline]
11013        unsafe fn encode(
11014            self,
11015            encoder: &mut fidl::encoding::Encoder<
11016                '_,
11017                fidl::encoding::DefaultFuchsiaResourceDialect,
11018            >,
11019            offset: usize,
11020            _depth: fidl::encoding::Depth,
11021        ) -> fidl::Result<()> {
11022            encoder.debug_check_bounds::<RunnerCallStrictOneWayRequest>(offset);
11023            // Delegate to tuple encoding.
11024            fidl::encoding::Encode::<RunnerCallStrictOneWayRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
11025                (
11026                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
11027                ),
11028                encoder, offset, _depth
11029            )
11030        }
11031    }
11032    unsafe impl<
11033            T0: fidl::encoding::Encode<
11034                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
11035                fidl::encoding::DefaultFuchsiaResourceDialect,
11036            >,
11037        >
11038        fidl::encoding::Encode<
11039            RunnerCallStrictOneWayRequest,
11040            fidl::encoding::DefaultFuchsiaResourceDialect,
11041        > for (T0,)
11042    {
11043        #[inline]
11044        unsafe fn encode(
11045            self,
11046            encoder: &mut fidl::encoding::Encoder<
11047                '_,
11048                fidl::encoding::DefaultFuchsiaResourceDialect,
11049            >,
11050            offset: usize,
11051            depth: fidl::encoding::Depth,
11052        ) -> fidl::Result<()> {
11053            encoder.debug_check_bounds::<RunnerCallStrictOneWayRequest>(offset);
11054            // Zero out padding regions. There's no need to apply masks
11055            // because the unmasked parts will be overwritten by fields.
11056            // Write the fields.
11057            self.0.encode(encoder, offset + 0, depth)?;
11058            Ok(())
11059        }
11060    }
11061
11062    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
11063        for RunnerCallStrictOneWayRequest
11064    {
11065        #[inline(always)]
11066        fn new_empty() -> Self {
11067            Self {
11068                target: fidl::new_empty!(
11069                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
11070                    fidl::encoding::DefaultFuchsiaResourceDialect
11071                ),
11072            }
11073        }
11074
11075        #[inline]
11076        unsafe fn decode(
11077            &mut self,
11078            decoder: &mut fidl::encoding::Decoder<
11079                '_,
11080                fidl::encoding::DefaultFuchsiaResourceDialect,
11081            >,
11082            offset: usize,
11083            _depth: fidl::encoding::Depth,
11084        ) -> fidl::Result<()> {
11085            decoder.debug_check_bounds::<Self>(offset);
11086            // Verify that padding bytes are zero.
11087            fidl::decode!(
11088                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
11089                fidl::encoding::DefaultFuchsiaResourceDialect,
11090                &mut self.target,
11091                decoder,
11092                offset + 0,
11093                _depth
11094            )?;
11095            Ok(())
11096        }
11097    }
11098
11099    impl fidl::encoding::ResourceTypeMarker for RunnerCallStrictTwoWayErrRequest {
11100        type Borrowed<'a> = &'a mut Self;
11101        fn take_or_borrow<'a>(
11102            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
11103        ) -> Self::Borrowed<'a> {
11104            value
11105        }
11106    }
11107
11108    unsafe impl fidl::encoding::TypeMarker for RunnerCallStrictTwoWayErrRequest {
11109        type Owned = Self;
11110
11111        #[inline(always)]
11112        fn inline_align(_context: fidl::encoding::Context) -> usize {
11113            4
11114        }
11115
11116        #[inline(always)]
11117        fn inline_size(_context: fidl::encoding::Context) -> usize {
11118            4
11119        }
11120    }
11121
11122    unsafe impl
11123        fidl::encoding::Encode<
11124            RunnerCallStrictTwoWayErrRequest,
11125            fidl::encoding::DefaultFuchsiaResourceDialect,
11126        > for &mut RunnerCallStrictTwoWayErrRequest
11127    {
11128        #[inline]
11129        unsafe fn encode(
11130            self,
11131            encoder: &mut fidl::encoding::Encoder<
11132                '_,
11133                fidl::encoding::DefaultFuchsiaResourceDialect,
11134            >,
11135            offset: usize,
11136            _depth: fidl::encoding::Depth,
11137        ) -> fidl::Result<()> {
11138            encoder.debug_check_bounds::<RunnerCallStrictTwoWayErrRequest>(offset);
11139            // Delegate to tuple encoding.
11140            fidl::encoding::Encode::<RunnerCallStrictTwoWayErrRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
11141                (
11142                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
11143                ),
11144                encoder, offset, _depth
11145            )
11146        }
11147    }
11148    unsafe impl<
11149            T0: fidl::encoding::Encode<
11150                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
11151                fidl::encoding::DefaultFuchsiaResourceDialect,
11152            >,
11153        >
11154        fidl::encoding::Encode<
11155            RunnerCallStrictTwoWayErrRequest,
11156            fidl::encoding::DefaultFuchsiaResourceDialect,
11157        > for (T0,)
11158    {
11159        #[inline]
11160        unsafe fn encode(
11161            self,
11162            encoder: &mut fidl::encoding::Encoder<
11163                '_,
11164                fidl::encoding::DefaultFuchsiaResourceDialect,
11165            >,
11166            offset: usize,
11167            depth: fidl::encoding::Depth,
11168        ) -> fidl::Result<()> {
11169            encoder.debug_check_bounds::<RunnerCallStrictTwoWayErrRequest>(offset);
11170            // Zero out padding regions. There's no need to apply masks
11171            // because the unmasked parts will be overwritten by fields.
11172            // Write the fields.
11173            self.0.encode(encoder, offset + 0, depth)?;
11174            Ok(())
11175        }
11176    }
11177
11178    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
11179        for RunnerCallStrictTwoWayErrRequest
11180    {
11181        #[inline(always)]
11182        fn new_empty() -> Self {
11183            Self {
11184                target: fidl::new_empty!(
11185                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
11186                    fidl::encoding::DefaultFuchsiaResourceDialect
11187                ),
11188            }
11189        }
11190
11191        #[inline]
11192        unsafe fn decode(
11193            &mut self,
11194            decoder: &mut fidl::encoding::Decoder<
11195                '_,
11196                fidl::encoding::DefaultFuchsiaResourceDialect,
11197            >,
11198            offset: usize,
11199            _depth: fidl::encoding::Depth,
11200        ) -> fidl::Result<()> {
11201            decoder.debug_check_bounds::<Self>(offset);
11202            // Verify that padding bytes are zero.
11203            fidl::decode!(
11204                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
11205                fidl::encoding::DefaultFuchsiaResourceDialect,
11206                &mut self.target,
11207                decoder,
11208                offset + 0,
11209                _depth
11210            )?;
11211            Ok(())
11212        }
11213    }
11214
11215    impl fidl::encoding::ResourceTypeMarker for RunnerCallStrictTwoWayFieldsErrRequest {
11216        type Borrowed<'a> = &'a mut Self;
11217        fn take_or_borrow<'a>(
11218            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
11219        ) -> Self::Borrowed<'a> {
11220            value
11221        }
11222    }
11223
11224    unsafe impl fidl::encoding::TypeMarker for RunnerCallStrictTwoWayFieldsErrRequest {
11225        type Owned = Self;
11226
11227        #[inline(always)]
11228        fn inline_align(_context: fidl::encoding::Context) -> usize {
11229            4
11230        }
11231
11232        #[inline(always)]
11233        fn inline_size(_context: fidl::encoding::Context) -> usize {
11234            4
11235        }
11236    }
11237
11238    unsafe impl
11239        fidl::encoding::Encode<
11240            RunnerCallStrictTwoWayFieldsErrRequest,
11241            fidl::encoding::DefaultFuchsiaResourceDialect,
11242        > for &mut RunnerCallStrictTwoWayFieldsErrRequest
11243    {
11244        #[inline]
11245        unsafe fn encode(
11246            self,
11247            encoder: &mut fidl::encoding::Encoder<
11248                '_,
11249                fidl::encoding::DefaultFuchsiaResourceDialect,
11250            >,
11251            offset: usize,
11252            _depth: fidl::encoding::Depth,
11253        ) -> fidl::Result<()> {
11254            encoder.debug_check_bounds::<RunnerCallStrictTwoWayFieldsErrRequest>(offset);
11255            // Delegate to tuple encoding.
11256            fidl::encoding::Encode::<RunnerCallStrictTwoWayFieldsErrRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
11257                (
11258                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
11259                ),
11260                encoder, offset, _depth
11261            )
11262        }
11263    }
11264    unsafe impl<
11265            T0: fidl::encoding::Encode<
11266                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
11267                fidl::encoding::DefaultFuchsiaResourceDialect,
11268            >,
11269        >
11270        fidl::encoding::Encode<
11271            RunnerCallStrictTwoWayFieldsErrRequest,
11272            fidl::encoding::DefaultFuchsiaResourceDialect,
11273        > for (T0,)
11274    {
11275        #[inline]
11276        unsafe fn encode(
11277            self,
11278            encoder: &mut fidl::encoding::Encoder<
11279                '_,
11280                fidl::encoding::DefaultFuchsiaResourceDialect,
11281            >,
11282            offset: usize,
11283            depth: fidl::encoding::Depth,
11284        ) -> fidl::Result<()> {
11285            encoder.debug_check_bounds::<RunnerCallStrictTwoWayFieldsErrRequest>(offset);
11286            // Zero out padding regions. There's no need to apply masks
11287            // because the unmasked parts will be overwritten by fields.
11288            // Write the fields.
11289            self.0.encode(encoder, offset + 0, depth)?;
11290            Ok(())
11291        }
11292    }
11293
11294    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
11295        for RunnerCallStrictTwoWayFieldsErrRequest
11296    {
11297        #[inline(always)]
11298        fn new_empty() -> Self {
11299            Self {
11300                target: fidl::new_empty!(
11301                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
11302                    fidl::encoding::DefaultFuchsiaResourceDialect
11303                ),
11304            }
11305        }
11306
11307        #[inline]
11308        unsafe fn decode(
11309            &mut self,
11310            decoder: &mut fidl::encoding::Decoder<
11311                '_,
11312                fidl::encoding::DefaultFuchsiaResourceDialect,
11313            >,
11314            offset: usize,
11315            _depth: fidl::encoding::Depth,
11316        ) -> fidl::Result<()> {
11317            decoder.debug_check_bounds::<Self>(offset);
11318            // Verify that padding bytes are zero.
11319            fidl::decode!(
11320                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
11321                fidl::encoding::DefaultFuchsiaResourceDialect,
11322                &mut self.target,
11323                decoder,
11324                offset + 0,
11325                _depth
11326            )?;
11327            Ok(())
11328        }
11329    }
11330
11331    impl fidl::encoding::ResourceTypeMarker for RunnerCallStrictTwoWayFieldsRequest {
11332        type Borrowed<'a> = &'a mut Self;
11333        fn take_or_borrow<'a>(
11334            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
11335        ) -> Self::Borrowed<'a> {
11336            value
11337        }
11338    }
11339
11340    unsafe impl fidl::encoding::TypeMarker for RunnerCallStrictTwoWayFieldsRequest {
11341        type Owned = Self;
11342
11343        #[inline(always)]
11344        fn inline_align(_context: fidl::encoding::Context) -> usize {
11345            4
11346        }
11347
11348        #[inline(always)]
11349        fn inline_size(_context: fidl::encoding::Context) -> usize {
11350            4
11351        }
11352    }
11353
11354    unsafe impl
11355        fidl::encoding::Encode<
11356            RunnerCallStrictTwoWayFieldsRequest,
11357            fidl::encoding::DefaultFuchsiaResourceDialect,
11358        > for &mut RunnerCallStrictTwoWayFieldsRequest
11359    {
11360        #[inline]
11361        unsafe fn encode(
11362            self,
11363            encoder: &mut fidl::encoding::Encoder<
11364                '_,
11365                fidl::encoding::DefaultFuchsiaResourceDialect,
11366            >,
11367            offset: usize,
11368            _depth: fidl::encoding::Depth,
11369        ) -> fidl::Result<()> {
11370            encoder.debug_check_bounds::<RunnerCallStrictTwoWayFieldsRequest>(offset);
11371            // Delegate to tuple encoding.
11372            fidl::encoding::Encode::<RunnerCallStrictTwoWayFieldsRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
11373                (
11374                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
11375                ),
11376                encoder, offset, _depth
11377            )
11378        }
11379    }
11380    unsafe impl<
11381            T0: fidl::encoding::Encode<
11382                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
11383                fidl::encoding::DefaultFuchsiaResourceDialect,
11384            >,
11385        >
11386        fidl::encoding::Encode<
11387            RunnerCallStrictTwoWayFieldsRequest,
11388            fidl::encoding::DefaultFuchsiaResourceDialect,
11389        > for (T0,)
11390    {
11391        #[inline]
11392        unsafe fn encode(
11393            self,
11394            encoder: &mut fidl::encoding::Encoder<
11395                '_,
11396                fidl::encoding::DefaultFuchsiaResourceDialect,
11397            >,
11398            offset: usize,
11399            depth: fidl::encoding::Depth,
11400        ) -> fidl::Result<()> {
11401            encoder.debug_check_bounds::<RunnerCallStrictTwoWayFieldsRequest>(offset);
11402            // Zero out padding regions. There's no need to apply masks
11403            // because the unmasked parts will be overwritten by fields.
11404            // Write the fields.
11405            self.0.encode(encoder, offset + 0, depth)?;
11406            Ok(())
11407        }
11408    }
11409
11410    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
11411        for RunnerCallStrictTwoWayFieldsRequest
11412    {
11413        #[inline(always)]
11414        fn new_empty() -> Self {
11415            Self {
11416                target: fidl::new_empty!(
11417                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
11418                    fidl::encoding::DefaultFuchsiaResourceDialect
11419                ),
11420            }
11421        }
11422
11423        #[inline]
11424        unsafe fn decode(
11425            &mut self,
11426            decoder: &mut fidl::encoding::Decoder<
11427                '_,
11428                fidl::encoding::DefaultFuchsiaResourceDialect,
11429            >,
11430            offset: usize,
11431            _depth: fidl::encoding::Depth,
11432        ) -> fidl::Result<()> {
11433            decoder.debug_check_bounds::<Self>(offset);
11434            // Verify that padding bytes are zero.
11435            fidl::decode!(
11436                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
11437                fidl::encoding::DefaultFuchsiaResourceDialect,
11438                &mut self.target,
11439                decoder,
11440                offset + 0,
11441                _depth
11442            )?;
11443            Ok(())
11444        }
11445    }
11446
11447    impl fidl::encoding::ResourceTypeMarker for RunnerCallStrictTwoWayRequest {
11448        type Borrowed<'a> = &'a mut Self;
11449        fn take_or_borrow<'a>(
11450            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
11451        ) -> Self::Borrowed<'a> {
11452            value
11453        }
11454    }
11455
11456    unsafe impl fidl::encoding::TypeMarker for RunnerCallStrictTwoWayRequest {
11457        type Owned = Self;
11458
11459        #[inline(always)]
11460        fn inline_align(_context: fidl::encoding::Context) -> usize {
11461            4
11462        }
11463
11464        #[inline(always)]
11465        fn inline_size(_context: fidl::encoding::Context) -> usize {
11466            4
11467        }
11468    }
11469
11470    unsafe impl
11471        fidl::encoding::Encode<
11472            RunnerCallStrictTwoWayRequest,
11473            fidl::encoding::DefaultFuchsiaResourceDialect,
11474        > for &mut RunnerCallStrictTwoWayRequest
11475    {
11476        #[inline]
11477        unsafe fn encode(
11478            self,
11479            encoder: &mut fidl::encoding::Encoder<
11480                '_,
11481                fidl::encoding::DefaultFuchsiaResourceDialect,
11482            >,
11483            offset: usize,
11484            _depth: fidl::encoding::Depth,
11485        ) -> fidl::Result<()> {
11486            encoder.debug_check_bounds::<RunnerCallStrictTwoWayRequest>(offset);
11487            // Delegate to tuple encoding.
11488            fidl::encoding::Encode::<RunnerCallStrictTwoWayRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
11489                (
11490                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
11491                ),
11492                encoder, offset, _depth
11493            )
11494        }
11495    }
11496    unsafe impl<
11497            T0: fidl::encoding::Encode<
11498                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
11499                fidl::encoding::DefaultFuchsiaResourceDialect,
11500            >,
11501        >
11502        fidl::encoding::Encode<
11503            RunnerCallStrictTwoWayRequest,
11504            fidl::encoding::DefaultFuchsiaResourceDialect,
11505        > for (T0,)
11506    {
11507        #[inline]
11508        unsafe fn encode(
11509            self,
11510            encoder: &mut fidl::encoding::Encoder<
11511                '_,
11512                fidl::encoding::DefaultFuchsiaResourceDialect,
11513            >,
11514            offset: usize,
11515            depth: fidl::encoding::Depth,
11516        ) -> fidl::Result<()> {
11517            encoder.debug_check_bounds::<RunnerCallStrictTwoWayRequest>(offset);
11518            // Zero out padding regions. There's no need to apply masks
11519            // because the unmasked parts will be overwritten by fields.
11520            // Write the fields.
11521            self.0.encode(encoder, offset + 0, depth)?;
11522            Ok(())
11523        }
11524    }
11525
11526    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
11527        for RunnerCallStrictTwoWayRequest
11528    {
11529        #[inline(always)]
11530        fn new_empty() -> Self {
11531            Self {
11532                target: fidl::new_empty!(
11533                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
11534                    fidl::encoding::DefaultFuchsiaResourceDialect
11535                ),
11536            }
11537        }
11538
11539        #[inline]
11540        unsafe fn decode(
11541            &mut self,
11542            decoder: &mut fidl::encoding::Decoder<
11543                '_,
11544                fidl::encoding::DefaultFuchsiaResourceDialect,
11545            >,
11546            offset: usize,
11547            _depth: fidl::encoding::Depth,
11548        ) -> fidl::Result<()> {
11549            decoder.debug_check_bounds::<Self>(offset);
11550            // Verify that padding bytes are zero.
11551            fidl::decode!(
11552                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
11553                fidl::encoding::DefaultFuchsiaResourceDialect,
11554                &mut self.target,
11555                decoder,
11556                offset + 0,
11557                _depth
11558            )?;
11559            Ok(())
11560        }
11561    }
11562
11563    impl fidl::encoding::ResourceTypeMarker for RunnerCallTwoWayNoPayloadRequest {
11564        type Borrowed<'a> = &'a mut Self;
11565        fn take_or_borrow<'a>(
11566            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
11567        ) -> Self::Borrowed<'a> {
11568            value
11569        }
11570    }
11571
11572    unsafe impl fidl::encoding::TypeMarker for RunnerCallTwoWayNoPayloadRequest {
11573        type Owned = Self;
11574
11575        #[inline(always)]
11576        fn inline_align(_context: fidl::encoding::Context) -> usize {
11577            4
11578        }
11579
11580        #[inline(always)]
11581        fn inline_size(_context: fidl::encoding::Context) -> usize {
11582            4
11583        }
11584    }
11585
11586    unsafe impl
11587        fidl::encoding::Encode<
11588            RunnerCallTwoWayNoPayloadRequest,
11589            fidl::encoding::DefaultFuchsiaResourceDialect,
11590        > for &mut RunnerCallTwoWayNoPayloadRequest
11591    {
11592        #[inline]
11593        unsafe fn encode(
11594            self,
11595            encoder: &mut fidl::encoding::Encoder<
11596                '_,
11597                fidl::encoding::DefaultFuchsiaResourceDialect,
11598            >,
11599            offset: usize,
11600            _depth: fidl::encoding::Depth,
11601        ) -> fidl::Result<()> {
11602            encoder.debug_check_bounds::<RunnerCallTwoWayNoPayloadRequest>(offset);
11603            // Delegate to tuple encoding.
11604            fidl::encoding::Encode::<RunnerCallTwoWayNoPayloadRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
11605                (
11606                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
11607                ),
11608                encoder, offset, _depth
11609            )
11610        }
11611    }
11612    unsafe impl<
11613            T0: fidl::encoding::Encode<
11614                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
11615                fidl::encoding::DefaultFuchsiaResourceDialect,
11616            >,
11617        >
11618        fidl::encoding::Encode<
11619            RunnerCallTwoWayNoPayloadRequest,
11620            fidl::encoding::DefaultFuchsiaResourceDialect,
11621        > for (T0,)
11622    {
11623        #[inline]
11624        unsafe fn encode(
11625            self,
11626            encoder: &mut fidl::encoding::Encoder<
11627                '_,
11628                fidl::encoding::DefaultFuchsiaResourceDialect,
11629            >,
11630            offset: usize,
11631            depth: fidl::encoding::Depth,
11632        ) -> fidl::Result<()> {
11633            encoder.debug_check_bounds::<RunnerCallTwoWayNoPayloadRequest>(offset);
11634            // Zero out padding regions. There's no need to apply masks
11635            // because the unmasked parts will be overwritten by fields.
11636            // Write the fields.
11637            self.0.encode(encoder, offset + 0, depth)?;
11638            Ok(())
11639        }
11640    }
11641
11642    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
11643        for RunnerCallTwoWayNoPayloadRequest
11644    {
11645        #[inline(always)]
11646        fn new_empty() -> Self {
11647            Self {
11648                target: fidl::new_empty!(
11649                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
11650                    fidl::encoding::DefaultFuchsiaResourceDialect
11651                ),
11652            }
11653        }
11654
11655        #[inline]
11656        unsafe fn decode(
11657            &mut self,
11658            decoder: &mut fidl::encoding::Decoder<
11659                '_,
11660                fidl::encoding::DefaultFuchsiaResourceDialect,
11661            >,
11662            offset: usize,
11663            _depth: fidl::encoding::Depth,
11664        ) -> fidl::Result<()> {
11665            decoder.debug_check_bounds::<Self>(offset);
11666            // Verify that padding bytes are zero.
11667            fidl::decode!(
11668                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
11669                fidl::encoding::DefaultFuchsiaResourceDialect,
11670                &mut self.target,
11671                decoder,
11672                offset + 0,
11673                _depth
11674            )?;
11675            Ok(())
11676        }
11677    }
11678
11679    impl fidl::encoding::ResourceTypeMarker for RunnerCallTwoWayStructPayloadErrRequest {
11680        type Borrowed<'a> = &'a mut Self;
11681        fn take_or_borrow<'a>(
11682            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
11683        ) -> Self::Borrowed<'a> {
11684            value
11685        }
11686    }
11687
11688    unsafe impl fidl::encoding::TypeMarker for RunnerCallTwoWayStructPayloadErrRequest {
11689        type Owned = Self;
11690
11691        #[inline(always)]
11692        fn inline_align(_context: fidl::encoding::Context) -> usize {
11693            4
11694        }
11695
11696        #[inline(always)]
11697        fn inline_size(_context: fidl::encoding::Context) -> usize {
11698            4
11699        }
11700    }
11701
11702    unsafe impl
11703        fidl::encoding::Encode<
11704            RunnerCallTwoWayStructPayloadErrRequest,
11705            fidl::encoding::DefaultFuchsiaResourceDialect,
11706        > for &mut RunnerCallTwoWayStructPayloadErrRequest
11707    {
11708        #[inline]
11709        unsafe fn encode(
11710            self,
11711            encoder: &mut fidl::encoding::Encoder<
11712                '_,
11713                fidl::encoding::DefaultFuchsiaResourceDialect,
11714            >,
11715            offset: usize,
11716            _depth: fidl::encoding::Depth,
11717        ) -> fidl::Result<()> {
11718            encoder.debug_check_bounds::<RunnerCallTwoWayStructPayloadErrRequest>(offset);
11719            // Delegate to tuple encoding.
11720            fidl::encoding::Encode::<RunnerCallTwoWayStructPayloadErrRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
11721                (
11722                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
11723                ),
11724                encoder, offset, _depth
11725            )
11726        }
11727    }
11728    unsafe impl<
11729            T0: fidl::encoding::Encode<
11730                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
11731                fidl::encoding::DefaultFuchsiaResourceDialect,
11732            >,
11733        >
11734        fidl::encoding::Encode<
11735            RunnerCallTwoWayStructPayloadErrRequest,
11736            fidl::encoding::DefaultFuchsiaResourceDialect,
11737        > for (T0,)
11738    {
11739        #[inline]
11740        unsafe fn encode(
11741            self,
11742            encoder: &mut fidl::encoding::Encoder<
11743                '_,
11744                fidl::encoding::DefaultFuchsiaResourceDialect,
11745            >,
11746            offset: usize,
11747            depth: fidl::encoding::Depth,
11748        ) -> fidl::Result<()> {
11749            encoder.debug_check_bounds::<RunnerCallTwoWayStructPayloadErrRequest>(offset);
11750            // Zero out padding regions. There's no need to apply masks
11751            // because the unmasked parts will be overwritten by fields.
11752            // Write the fields.
11753            self.0.encode(encoder, offset + 0, depth)?;
11754            Ok(())
11755        }
11756    }
11757
11758    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
11759        for RunnerCallTwoWayStructPayloadErrRequest
11760    {
11761        #[inline(always)]
11762        fn new_empty() -> Self {
11763            Self {
11764                target: fidl::new_empty!(
11765                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
11766                    fidl::encoding::DefaultFuchsiaResourceDialect
11767                ),
11768            }
11769        }
11770
11771        #[inline]
11772        unsafe fn decode(
11773            &mut self,
11774            decoder: &mut fidl::encoding::Decoder<
11775                '_,
11776                fidl::encoding::DefaultFuchsiaResourceDialect,
11777            >,
11778            offset: usize,
11779            _depth: fidl::encoding::Depth,
11780        ) -> fidl::Result<()> {
11781            decoder.debug_check_bounds::<Self>(offset);
11782            // Verify that padding bytes are zero.
11783            fidl::decode!(
11784                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
11785                fidl::encoding::DefaultFuchsiaResourceDialect,
11786                &mut self.target,
11787                decoder,
11788                offset + 0,
11789                _depth
11790            )?;
11791            Ok(())
11792        }
11793    }
11794
11795    impl fidl::encoding::ResourceTypeMarker for RunnerCallTwoWayStructPayloadRequest {
11796        type Borrowed<'a> = &'a mut Self;
11797        fn take_or_borrow<'a>(
11798            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
11799        ) -> Self::Borrowed<'a> {
11800            value
11801        }
11802    }
11803
11804    unsafe impl fidl::encoding::TypeMarker for RunnerCallTwoWayStructPayloadRequest {
11805        type Owned = Self;
11806
11807        #[inline(always)]
11808        fn inline_align(_context: fidl::encoding::Context) -> usize {
11809            4
11810        }
11811
11812        #[inline(always)]
11813        fn inline_size(_context: fidl::encoding::Context) -> usize {
11814            4
11815        }
11816    }
11817
11818    unsafe impl
11819        fidl::encoding::Encode<
11820            RunnerCallTwoWayStructPayloadRequest,
11821            fidl::encoding::DefaultFuchsiaResourceDialect,
11822        > for &mut RunnerCallTwoWayStructPayloadRequest
11823    {
11824        #[inline]
11825        unsafe fn encode(
11826            self,
11827            encoder: &mut fidl::encoding::Encoder<
11828                '_,
11829                fidl::encoding::DefaultFuchsiaResourceDialect,
11830            >,
11831            offset: usize,
11832            _depth: fidl::encoding::Depth,
11833        ) -> fidl::Result<()> {
11834            encoder.debug_check_bounds::<RunnerCallTwoWayStructPayloadRequest>(offset);
11835            // Delegate to tuple encoding.
11836            fidl::encoding::Encode::<RunnerCallTwoWayStructPayloadRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
11837                (
11838                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
11839                ),
11840                encoder, offset, _depth
11841            )
11842        }
11843    }
11844    unsafe impl<
11845            T0: fidl::encoding::Encode<
11846                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
11847                fidl::encoding::DefaultFuchsiaResourceDialect,
11848            >,
11849        >
11850        fidl::encoding::Encode<
11851            RunnerCallTwoWayStructPayloadRequest,
11852            fidl::encoding::DefaultFuchsiaResourceDialect,
11853        > for (T0,)
11854    {
11855        #[inline]
11856        unsafe fn encode(
11857            self,
11858            encoder: &mut fidl::encoding::Encoder<
11859                '_,
11860                fidl::encoding::DefaultFuchsiaResourceDialect,
11861            >,
11862            offset: usize,
11863            depth: fidl::encoding::Depth,
11864        ) -> fidl::Result<()> {
11865            encoder.debug_check_bounds::<RunnerCallTwoWayStructPayloadRequest>(offset);
11866            // Zero out padding regions. There's no need to apply masks
11867            // because the unmasked parts will be overwritten by fields.
11868            // Write the fields.
11869            self.0.encode(encoder, offset + 0, depth)?;
11870            Ok(())
11871        }
11872    }
11873
11874    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
11875        for RunnerCallTwoWayStructPayloadRequest
11876    {
11877        #[inline(always)]
11878        fn new_empty() -> Self {
11879            Self {
11880                target: fidl::new_empty!(
11881                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
11882                    fidl::encoding::DefaultFuchsiaResourceDialect
11883                ),
11884            }
11885        }
11886
11887        #[inline]
11888        unsafe fn decode(
11889            &mut self,
11890            decoder: &mut fidl::encoding::Decoder<
11891                '_,
11892                fidl::encoding::DefaultFuchsiaResourceDialect,
11893            >,
11894            offset: usize,
11895            _depth: fidl::encoding::Depth,
11896        ) -> fidl::Result<()> {
11897            decoder.debug_check_bounds::<Self>(offset);
11898            // Verify that padding bytes are zero.
11899            fidl::decode!(
11900                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
11901                fidl::encoding::DefaultFuchsiaResourceDialect,
11902                &mut self.target,
11903                decoder,
11904                offset + 0,
11905                _depth
11906            )?;
11907            Ok(())
11908        }
11909    }
11910
11911    impl fidl::encoding::ResourceTypeMarker for RunnerCallTwoWayStructRequestRequest {
11912        type Borrowed<'a> = &'a mut Self;
11913        fn take_or_borrow<'a>(
11914            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
11915        ) -> Self::Borrowed<'a> {
11916            value
11917        }
11918    }
11919
11920    unsafe impl fidl::encoding::TypeMarker for RunnerCallTwoWayStructRequestRequest {
11921        type Owned = Self;
11922
11923        #[inline(always)]
11924        fn inline_align(_context: fidl::encoding::Context) -> usize {
11925            4
11926        }
11927
11928        #[inline(always)]
11929        fn inline_size(_context: fidl::encoding::Context) -> usize {
11930            8
11931        }
11932    }
11933
11934    unsafe impl
11935        fidl::encoding::Encode<
11936            RunnerCallTwoWayStructRequestRequest,
11937            fidl::encoding::DefaultFuchsiaResourceDialect,
11938        > for &mut RunnerCallTwoWayStructRequestRequest
11939    {
11940        #[inline]
11941        unsafe fn encode(
11942            self,
11943            encoder: &mut fidl::encoding::Encoder<
11944                '_,
11945                fidl::encoding::DefaultFuchsiaResourceDialect,
11946            >,
11947            offset: usize,
11948            _depth: fidl::encoding::Depth,
11949        ) -> fidl::Result<()> {
11950            encoder.debug_check_bounds::<RunnerCallTwoWayStructRequestRequest>(offset);
11951            // Delegate to tuple encoding.
11952            fidl::encoding::Encode::<RunnerCallTwoWayStructRequestRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
11953                (
11954                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
11955                    <NonEmptyPayload as fidl::encoding::ValueTypeMarker>::borrow(&self.request),
11956                ),
11957                encoder, offset, _depth
11958            )
11959        }
11960    }
11961    unsafe impl<
11962            T0: fidl::encoding::Encode<
11963                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
11964                fidl::encoding::DefaultFuchsiaResourceDialect,
11965            >,
11966            T1: fidl::encoding::Encode<NonEmptyPayload, fidl::encoding::DefaultFuchsiaResourceDialect>,
11967        >
11968        fidl::encoding::Encode<
11969            RunnerCallTwoWayStructRequestRequest,
11970            fidl::encoding::DefaultFuchsiaResourceDialect,
11971        > for (T0, T1)
11972    {
11973        #[inline]
11974        unsafe fn encode(
11975            self,
11976            encoder: &mut fidl::encoding::Encoder<
11977                '_,
11978                fidl::encoding::DefaultFuchsiaResourceDialect,
11979            >,
11980            offset: usize,
11981            depth: fidl::encoding::Depth,
11982        ) -> fidl::Result<()> {
11983            encoder.debug_check_bounds::<RunnerCallTwoWayStructRequestRequest>(offset);
11984            // Zero out padding regions. There's no need to apply masks
11985            // because the unmasked parts will be overwritten by fields.
11986            // Write the fields.
11987            self.0.encode(encoder, offset + 0, depth)?;
11988            self.1.encode(encoder, offset + 4, depth)?;
11989            Ok(())
11990        }
11991    }
11992
11993    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
11994        for RunnerCallTwoWayStructRequestRequest
11995    {
11996        #[inline(always)]
11997        fn new_empty() -> Self {
11998            Self {
11999                target: fidl::new_empty!(
12000                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
12001                    fidl::encoding::DefaultFuchsiaResourceDialect
12002                ),
12003                request: fidl::new_empty!(
12004                    NonEmptyPayload,
12005                    fidl::encoding::DefaultFuchsiaResourceDialect
12006                ),
12007            }
12008        }
12009
12010        #[inline]
12011        unsafe fn decode(
12012            &mut self,
12013            decoder: &mut fidl::encoding::Decoder<
12014                '_,
12015                fidl::encoding::DefaultFuchsiaResourceDialect,
12016            >,
12017            offset: usize,
12018            _depth: fidl::encoding::Depth,
12019        ) -> fidl::Result<()> {
12020            decoder.debug_check_bounds::<Self>(offset);
12021            // Verify that padding bytes are zero.
12022            fidl::decode!(
12023                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
12024                fidl::encoding::DefaultFuchsiaResourceDialect,
12025                &mut self.target,
12026                decoder,
12027                offset + 0,
12028                _depth
12029            )?;
12030            fidl::decode!(
12031                NonEmptyPayload,
12032                fidl::encoding::DefaultFuchsiaResourceDialect,
12033                &mut self.request,
12034                decoder,
12035                offset + 4,
12036                _depth
12037            )?;
12038            Ok(())
12039        }
12040    }
12041
12042    impl fidl::encoding::ResourceTypeMarker for RunnerCallTwoWayTablePayloadRequest {
12043        type Borrowed<'a> = &'a mut Self;
12044        fn take_or_borrow<'a>(
12045            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
12046        ) -> Self::Borrowed<'a> {
12047            value
12048        }
12049    }
12050
12051    unsafe impl fidl::encoding::TypeMarker for RunnerCallTwoWayTablePayloadRequest {
12052        type Owned = Self;
12053
12054        #[inline(always)]
12055        fn inline_align(_context: fidl::encoding::Context) -> usize {
12056            4
12057        }
12058
12059        #[inline(always)]
12060        fn inline_size(_context: fidl::encoding::Context) -> usize {
12061            4
12062        }
12063    }
12064
12065    unsafe impl
12066        fidl::encoding::Encode<
12067            RunnerCallTwoWayTablePayloadRequest,
12068            fidl::encoding::DefaultFuchsiaResourceDialect,
12069        > for &mut RunnerCallTwoWayTablePayloadRequest
12070    {
12071        #[inline]
12072        unsafe fn encode(
12073            self,
12074            encoder: &mut fidl::encoding::Encoder<
12075                '_,
12076                fidl::encoding::DefaultFuchsiaResourceDialect,
12077            >,
12078            offset: usize,
12079            _depth: fidl::encoding::Depth,
12080        ) -> fidl::Result<()> {
12081            encoder.debug_check_bounds::<RunnerCallTwoWayTablePayloadRequest>(offset);
12082            // Delegate to tuple encoding.
12083            fidl::encoding::Encode::<RunnerCallTwoWayTablePayloadRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
12084                (
12085                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
12086                ),
12087                encoder, offset, _depth
12088            )
12089        }
12090    }
12091    unsafe impl<
12092            T0: fidl::encoding::Encode<
12093                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
12094                fidl::encoding::DefaultFuchsiaResourceDialect,
12095            >,
12096        >
12097        fidl::encoding::Encode<
12098            RunnerCallTwoWayTablePayloadRequest,
12099            fidl::encoding::DefaultFuchsiaResourceDialect,
12100        > for (T0,)
12101    {
12102        #[inline]
12103        unsafe fn encode(
12104            self,
12105            encoder: &mut fidl::encoding::Encoder<
12106                '_,
12107                fidl::encoding::DefaultFuchsiaResourceDialect,
12108            >,
12109            offset: usize,
12110            depth: fidl::encoding::Depth,
12111        ) -> fidl::Result<()> {
12112            encoder.debug_check_bounds::<RunnerCallTwoWayTablePayloadRequest>(offset);
12113            // Zero out padding regions. There's no need to apply masks
12114            // because the unmasked parts will be overwritten by fields.
12115            // Write the fields.
12116            self.0.encode(encoder, offset + 0, depth)?;
12117            Ok(())
12118        }
12119    }
12120
12121    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
12122        for RunnerCallTwoWayTablePayloadRequest
12123    {
12124        #[inline(always)]
12125        fn new_empty() -> Self {
12126            Self {
12127                target: fidl::new_empty!(
12128                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
12129                    fidl::encoding::DefaultFuchsiaResourceDialect
12130                ),
12131            }
12132        }
12133
12134        #[inline]
12135        unsafe fn decode(
12136            &mut self,
12137            decoder: &mut fidl::encoding::Decoder<
12138                '_,
12139                fidl::encoding::DefaultFuchsiaResourceDialect,
12140            >,
12141            offset: usize,
12142            _depth: fidl::encoding::Depth,
12143        ) -> fidl::Result<()> {
12144            decoder.debug_check_bounds::<Self>(offset);
12145            // Verify that padding bytes are zero.
12146            fidl::decode!(
12147                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
12148                fidl::encoding::DefaultFuchsiaResourceDialect,
12149                &mut self.target,
12150                decoder,
12151                offset + 0,
12152                _depth
12153            )?;
12154            Ok(())
12155        }
12156    }
12157
12158    impl fidl::encoding::ResourceTypeMarker for RunnerCallTwoWayTableRequestRequest {
12159        type Borrowed<'a> = &'a mut Self;
12160        fn take_or_borrow<'a>(
12161            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
12162        ) -> Self::Borrowed<'a> {
12163            value
12164        }
12165    }
12166
12167    unsafe impl fidl::encoding::TypeMarker for RunnerCallTwoWayTableRequestRequest {
12168        type Owned = Self;
12169
12170        #[inline(always)]
12171        fn inline_align(_context: fidl::encoding::Context) -> usize {
12172            8
12173        }
12174
12175        #[inline(always)]
12176        fn inline_size(_context: fidl::encoding::Context) -> usize {
12177            24
12178        }
12179    }
12180
12181    unsafe impl
12182        fidl::encoding::Encode<
12183            RunnerCallTwoWayTableRequestRequest,
12184            fidl::encoding::DefaultFuchsiaResourceDialect,
12185        > for &mut RunnerCallTwoWayTableRequestRequest
12186    {
12187        #[inline]
12188        unsafe fn encode(
12189            self,
12190            encoder: &mut fidl::encoding::Encoder<
12191                '_,
12192                fidl::encoding::DefaultFuchsiaResourceDialect,
12193            >,
12194            offset: usize,
12195            _depth: fidl::encoding::Depth,
12196        ) -> fidl::Result<()> {
12197            encoder.debug_check_bounds::<RunnerCallTwoWayTableRequestRequest>(offset);
12198            // Delegate to tuple encoding.
12199            fidl::encoding::Encode::<RunnerCallTwoWayTableRequestRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
12200                (
12201                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
12202                    <TablePayload as fidl::encoding::ValueTypeMarker>::borrow(&self.request),
12203                ),
12204                encoder, offset, _depth
12205            )
12206        }
12207    }
12208    unsafe impl<
12209            T0: fidl::encoding::Encode<
12210                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
12211                fidl::encoding::DefaultFuchsiaResourceDialect,
12212            >,
12213            T1: fidl::encoding::Encode<TablePayload, fidl::encoding::DefaultFuchsiaResourceDialect>,
12214        >
12215        fidl::encoding::Encode<
12216            RunnerCallTwoWayTableRequestRequest,
12217            fidl::encoding::DefaultFuchsiaResourceDialect,
12218        > for (T0, T1)
12219    {
12220        #[inline]
12221        unsafe fn encode(
12222            self,
12223            encoder: &mut fidl::encoding::Encoder<
12224                '_,
12225                fidl::encoding::DefaultFuchsiaResourceDialect,
12226            >,
12227            offset: usize,
12228            depth: fidl::encoding::Depth,
12229        ) -> fidl::Result<()> {
12230            encoder.debug_check_bounds::<RunnerCallTwoWayTableRequestRequest>(offset);
12231            // Zero out padding regions. There's no need to apply masks
12232            // because the unmasked parts will be overwritten by fields.
12233            unsafe {
12234                let ptr = encoder.buf.as_mut_ptr().add(offset).offset(0);
12235                (ptr as *mut u64).write_unaligned(0);
12236            }
12237            // Write the fields.
12238            self.0.encode(encoder, offset + 0, depth)?;
12239            self.1.encode(encoder, offset + 8, depth)?;
12240            Ok(())
12241        }
12242    }
12243
12244    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
12245        for RunnerCallTwoWayTableRequestRequest
12246    {
12247        #[inline(always)]
12248        fn new_empty() -> Self {
12249            Self {
12250                target: fidl::new_empty!(
12251                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
12252                    fidl::encoding::DefaultFuchsiaResourceDialect
12253                ),
12254                request: fidl::new_empty!(
12255                    TablePayload,
12256                    fidl::encoding::DefaultFuchsiaResourceDialect
12257                ),
12258            }
12259        }
12260
12261        #[inline]
12262        unsafe fn decode(
12263            &mut self,
12264            decoder: &mut fidl::encoding::Decoder<
12265                '_,
12266                fidl::encoding::DefaultFuchsiaResourceDialect,
12267            >,
12268            offset: usize,
12269            _depth: fidl::encoding::Depth,
12270        ) -> fidl::Result<()> {
12271            decoder.debug_check_bounds::<Self>(offset);
12272            // Verify that padding bytes are zero.
12273            let ptr = unsafe { decoder.buf.as_ptr().add(offset).offset(0) };
12274            let padval = unsafe { (ptr as *const u64).read_unaligned() };
12275            let mask = 0xffffffff00000000u64;
12276            let maskedval = padval & mask;
12277            if maskedval != 0 {
12278                return Err(fidl::Error::NonZeroPadding {
12279                    padding_start: offset + 0 + ((mask as u64).trailing_zeros() / 8) as usize,
12280                });
12281            }
12282            fidl::decode!(
12283                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
12284                fidl::encoding::DefaultFuchsiaResourceDialect,
12285                &mut self.target,
12286                decoder,
12287                offset + 0,
12288                _depth
12289            )?;
12290            fidl::decode!(
12291                TablePayload,
12292                fidl::encoding::DefaultFuchsiaResourceDialect,
12293                &mut self.request,
12294                decoder,
12295                offset + 8,
12296                _depth
12297            )?;
12298            Ok(())
12299        }
12300    }
12301
12302    impl fidl::encoding::ResourceTypeMarker for RunnerCallTwoWayUnionPayloadRequest {
12303        type Borrowed<'a> = &'a mut Self;
12304        fn take_or_borrow<'a>(
12305            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
12306        ) -> Self::Borrowed<'a> {
12307            value
12308        }
12309    }
12310
12311    unsafe impl fidl::encoding::TypeMarker for RunnerCallTwoWayUnionPayloadRequest {
12312        type Owned = Self;
12313
12314        #[inline(always)]
12315        fn inline_align(_context: fidl::encoding::Context) -> usize {
12316            4
12317        }
12318
12319        #[inline(always)]
12320        fn inline_size(_context: fidl::encoding::Context) -> usize {
12321            4
12322        }
12323    }
12324
12325    unsafe impl
12326        fidl::encoding::Encode<
12327            RunnerCallTwoWayUnionPayloadRequest,
12328            fidl::encoding::DefaultFuchsiaResourceDialect,
12329        > for &mut RunnerCallTwoWayUnionPayloadRequest
12330    {
12331        #[inline]
12332        unsafe fn encode(
12333            self,
12334            encoder: &mut fidl::encoding::Encoder<
12335                '_,
12336                fidl::encoding::DefaultFuchsiaResourceDialect,
12337            >,
12338            offset: usize,
12339            _depth: fidl::encoding::Depth,
12340        ) -> fidl::Result<()> {
12341            encoder.debug_check_bounds::<RunnerCallTwoWayUnionPayloadRequest>(offset);
12342            // Delegate to tuple encoding.
12343            fidl::encoding::Encode::<RunnerCallTwoWayUnionPayloadRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
12344                (
12345                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
12346                ),
12347                encoder, offset, _depth
12348            )
12349        }
12350    }
12351    unsafe impl<
12352            T0: fidl::encoding::Encode<
12353                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
12354                fidl::encoding::DefaultFuchsiaResourceDialect,
12355            >,
12356        >
12357        fidl::encoding::Encode<
12358            RunnerCallTwoWayUnionPayloadRequest,
12359            fidl::encoding::DefaultFuchsiaResourceDialect,
12360        > for (T0,)
12361    {
12362        #[inline]
12363        unsafe fn encode(
12364            self,
12365            encoder: &mut fidl::encoding::Encoder<
12366                '_,
12367                fidl::encoding::DefaultFuchsiaResourceDialect,
12368            >,
12369            offset: usize,
12370            depth: fidl::encoding::Depth,
12371        ) -> fidl::Result<()> {
12372            encoder.debug_check_bounds::<RunnerCallTwoWayUnionPayloadRequest>(offset);
12373            // Zero out padding regions. There's no need to apply masks
12374            // because the unmasked parts will be overwritten by fields.
12375            // Write the fields.
12376            self.0.encode(encoder, offset + 0, depth)?;
12377            Ok(())
12378        }
12379    }
12380
12381    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
12382        for RunnerCallTwoWayUnionPayloadRequest
12383    {
12384        #[inline(always)]
12385        fn new_empty() -> Self {
12386            Self {
12387                target: fidl::new_empty!(
12388                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
12389                    fidl::encoding::DefaultFuchsiaResourceDialect
12390                ),
12391            }
12392        }
12393
12394        #[inline]
12395        unsafe fn decode(
12396            &mut self,
12397            decoder: &mut fidl::encoding::Decoder<
12398                '_,
12399                fidl::encoding::DefaultFuchsiaResourceDialect,
12400            >,
12401            offset: usize,
12402            _depth: fidl::encoding::Depth,
12403        ) -> fidl::Result<()> {
12404            decoder.debug_check_bounds::<Self>(offset);
12405            // Verify that padding bytes are zero.
12406            fidl::decode!(
12407                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
12408                fidl::encoding::DefaultFuchsiaResourceDialect,
12409                &mut self.target,
12410                decoder,
12411                offset + 0,
12412                _depth
12413            )?;
12414            Ok(())
12415        }
12416    }
12417
12418    impl fidl::encoding::ResourceTypeMarker for RunnerCallTwoWayUnionRequestRequest {
12419        type Borrowed<'a> = &'a mut Self;
12420        fn take_or_borrow<'a>(
12421            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
12422        ) -> Self::Borrowed<'a> {
12423            value
12424        }
12425    }
12426
12427    unsafe impl fidl::encoding::TypeMarker for RunnerCallTwoWayUnionRequestRequest {
12428        type Owned = Self;
12429
12430        #[inline(always)]
12431        fn inline_align(_context: fidl::encoding::Context) -> usize {
12432            8
12433        }
12434
12435        #[inline(always)]
12436        fn inline_size(_context: fidl::encoding::Context) -> usize {
12437            24
12438        }
12439    }
12440
12441    unsafe impl
12442        fidl::encoding::Encode<
12443            RunnerCallTwoWayUnionRequestRequest,
12444            fidl::encoding::DefaultFuchsiaResourceDialect,
12445        > for &mut RunnerCallTwoWayUnionRequestRequest
12446    {
12447        #[inline]
12448        unsafe fn encode(
12449            self,
12450            encoder: &mut fidl::encoding::Encoder<
12451                '_,
12452                fidl::encoding::DefaultFuchsiaResourceDialect,
12453            >,
12454            offset: usize,
12455            _depth: fidl::encoding::Depth,
12456        ) -> fidl::Result<()> {
12457            encoder.debug_check_bounds::<RunnerCallTwoWayUnionRequestRequest>(offset);
12458            // Delegate to tuple encoding.
12459            fidl::encoding::Encode::<RunnerCallTwoWayUnionRequestRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
12460                (
12461                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
12462                    <UnionPayload as fidl::encoding::ValueTypeMarker>::borrow(&self.request),
12463                ),
12464                encoder, offset, _depth
12465            )
12466        }
12467    }
12468    unsafe impl<
12469            T0: fidl::encoding::Encode<
12470                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
12471                fidl::encoding::DefaultFuchsiaResourceDialect,
12472            >,
12473            T1: fidl::encoding::Encode<UnionPayload, fidl::encoding::DefaultFuchsiaResourceDialect>,
12474        >
12475        fidl::encoding::Encode<
12476            RunnerCallTwoWayUnionRequestRequest,
12477            fidl::encoding::DefaultFuchsiaResourceDialect,
12478        > for (T0, T1)
12479    {
12480        #[inline]
12481        unsafe fn encode(
12482            self,
12483            encoder: &mut fidl::encoding::Encoder<
12484                '_,
12485                fidl::encoding::DefaultFuchsiaResourceDialect,
12486            >,
12487            offset: usize,
12488            depth: fidl::encoding::Depth,
12489        ) -> fidl::Result<()> {
12490            encoder.debug_check_bounds::<RunnerCallTwoWayUnionRequestRequest>(offset);
12491            // Zero out padding regions. There's no need to apply masks
12492            // because the unmasked parts will be overwritten by fields.
12493            unsafe {
12494                let ptr = encoder.buf.as_mut_ptr().add(offset).offset(0);
12495                (ptr as *mut u64).write_unaligned(0);
12496            }
12497            // Write the fields.
12498            self.0.encode(encoder, offset + 0, depth)?;
12499            self.1.encode(encoder, offset + 8, depth)?;
12500            Ok(())
12501        }
12502    }
12503
12504    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
12505        for RunnerCallTwoWayUnionRequestRequest
12506    {
12507        #[inline(always)]
12508        fn new_empty() -> Self {
12509            Self {
12510                target: fidl::new_empty!(
12511                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
12512                    fidl::encoding::DefaultFuchsiaResourceDialect
12513                ),
12514                request: fidl::new_empty!(
12515                    UnionPayload,
12516                    fidl::encoding::DefaultFuchsiaResourceDialect
12517                ),
12518            }
12519        }
12520
12521        #[inline]
12522        unsafe fn decode(
12523            &mut self,
12524            decoder: &mut fidl::encoding::Decoder<
12525                '_,
12526                fidl::encoding::DefaultFuchsiaResourceDialect,
12527            >,
12528            offset: usize,
12529            _depth: fidl::encoding::Depth,
12530        ) -> fidl::Result<()> {
12531            decoder.debug_check_bounds::<Self>(offset);
12532            // Verify that padding bytes are zero.
12533            let ptr = unsafe { decoder.buf.as_ptr().add(offset).offset(0) };
12534            let padval = unsafe { (ptr as *const u64).read_unaligned() };
12535            let mask = 0xffffffff00000000u64;
12536            let maskedval = padval & mask;
12537            if maskedval != 0 {
12538                return Err(fidl::Error::NonZeroPadding {
12539                    padding_start: offset + 0 + ((mask as u64).trailing_zeros() / 8) as usize,
12540                });
12541            }
12542            fidl::decode!(
12543                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
12544                fidl::encoding::DefaultFuchsiaResourceDialect,
12545                &mut self.target,
12546                decoder,
12547                offset + 0,
12548                _depth
12549            )?;
12550            fidl::decode!(
12551                UnionPayload,
12552                fidl::encoding::DefaultFuchsiaResourceDialect,
12553                &mut self.request,
12554                decoder,
12555                offset + 8,
12556                _depth
12557            )?;
12558            Ok(())
12559        }
12560    }
12561
12562    impl fidl::encoding::ResourceTypeMarker for RunnerReceiveAjarEventsRequest {
12563        type Borrowed<'a> = &'a mut Self;
12564        fn take_or_borrow<'a>(
12565            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
12566        ) -> Self::Borrowed<'a> {
12567            value
12568        }
12569    }
12570
12571    unsafe impl fidl::encoding::TypeMarker for RunnerReceiveAjarEventsRequest {
12572        type Owned = Self;
12573
12574        #[inline(always)]
12575        fn inline_align(_context: fidl::encoding::Context) -> usize {
12576            4
12577        }
12578
12579        #[inline(always)]
12580        fn inline_size(_context: fidl::encoding::Context) -> usize {
12581            8
12582        }
12583    }
12584
12585    unsafe impl
12586        fidl::encoding::Encode<
12587            RunnerReceiveAjarEventsRequest,
12588            fidl::encoding::DefaultFuchsiaResourceDialect,
12589        > for &mut RunnerReceiveAjarEventsRequest
12590    {
12591        #[inline]
12592        unsafe fn encode(
12593            self,
12594            encoder: &mut fidl::encoding::Encoder<
12595                '_,
12596                fidl::encoding::DefaultFuchsiaResourceDialect,
12597            >,
12598            offset: usize,
12599            _depth: fidl::encoding::Depth,
12600        ) -> fidl::Result<()> {
12601            encoder.debug_check_bounds::<RunnerReceiveAjarEventsRequest>(offset);
12602            // Delegate to tuple encoding.
12603            fidl::encoding::Encode::<RunnerReceiveAjarEventsRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
12604                (
12605                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<AjarTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
12606                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<AjarTargetEventReporterMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.reporter),
12607                ),
12608                encoder, offset, _depth
12609            )
12610        }
12611    }
12612    unsafe impl<
12613            T0: fidl::encoding::Encode<
12614                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<AjarTargetMarker>>,
12615                fidl::encoding::DefaultFuchsiaResourceDialect,
12616            >,
12617            T1: fidl::encoding::Encode<
12618                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<AjarTargetEventReporterMarker>>,
12619                fidl::encoding::DefaultFuchsiaResourceDialect,
12620            >,
12621        >
12622        fidl::encoding::Encode<
12623            RunnerReceiveAjarEventsRequest,
12624            fidl::encoding::DefaultFuchsiaResourceDialect,
12625        > for (T0, T1)
12626    {
12627        #[inline]
12628        unsafe fn encode(
12629            self,
12630            encoder: &mut fidl::encoding::Encoder<
12631                '_,
12632                fidl::encoding::DefaultFuchsiaResourceDialect,
12633            >,
12634            offset: usize,
12635            depth: fidl::encoding::Depth,
12636        ) -> fidl::Result<()> {
12637            encoder.debug_check_bounds::<RunnerReceiveAjarEventsRequest>(offset);
12638            // Zero out padding regions. There's no need to apply masks
12639            // because the unmasked parts will be overwritten by fields.
12640            // Write the fields.
12641            self.0.encode(encoder, offset + 0, depth)?;
12642            self.1.encode(encoder, offset + 4, depth)?;
12643            Ok(())
12644        }
12645    }
12646
12647    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
12648        for RunnerReceiveAjarEventsRequest
12649    {
12650        #[inline(always)]
12651        fn new_empty() -> Self {
12652            Self {
12653                target: fidl::new_empty!(
12654                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<AjarTargetMarker>>,
12655                    fidl::encoding::DefaultFuchsiaResourceDialect
12656                ),
12657                reporter: fidl::new_empty!(
12658                    fidl::encoding::Endpoint<
12659                        fidl::endpoints::ClientEnd<AjarTargetEventReporterMarker>,
12660                    >,
12661                    fidl::encoding::DefaultFuchsiaResourceDialect
12662                ),
12663            }
12664        }
12665
12666        #[inline]
12667        unsafe fn decode(
12668            &mut self,
12669            decoder: &mut fidl::encoding::Decoder<
12670                '_,
12671                fidl::encoding::DefaultFuchsiaResourceDialect,
12672            >,
12673            offset: usize,
12674            _depth: fidl::encoding::Depth,
12675        ) -> fidl::Result<()> {
12676            decoder.debug_check_bounds::<Self>(offset);
12677            // Verify that padding bytes are zero.
12678            fidl::decode!(
12679                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<AjarTargetMarker>>,
12680                fidl::encoding::DefaultFuchsiaResourceDialect,
12681                &mut self.target,
12682                decoder,
12683                offset + 0,
12684                _depth
12685            )?;
12686            fidl::decode!(
12687                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<AjarTargetEventReporterMarker>>,
12688                fidl::encoding::DefaultFuchsiaResourceDialect,
12689                &mut self.reporter,
12690                decoder,
12691                offset + 4,
12692                _depth
12693            )?;
12694            Ok(())
12695        }
12696    }
12697
12698    impl fidl::encoding::ResourceTypeMarker for RunnerReceiveClosedEventsRequest {
12699        type Borrowed<'a> = &'a mut Self;
12700        fn take_or_borrow<'a>(
12701            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
12702        ) -> Self::Borrowed<'a> {
12703            value
12704        }
12705    }
12706
12707    unsafe impl fidl::encoding::TypeMarker for RunnerReceiveClosedEventsRequest {
12708        type Owned = Self;
12709
12710        #[inline(always)]
12711        fn inline_align(_context: fidl::encoding::Context) -> usize {
12712            4
12713        }
12714
12715        #[inline(always)]
12716        fn inline_size(_context: fidl::encoding::Context) -> usize {
12717            8
12718        }
12719    }
12720
12721    unsafe impl
12722        fidl::encoding::Encode<
12723            RunnerReceiveClosedEventsRequest,
12724            fidl::encoding::DefaultFuchsiaResourceDialect,
12725        > for &mut RunnerReceiveClosedEventsRequest
12726    {
12727        #[inline]
12728        unsafe fn encode(
12729            self,
12730            encoder: &mut fidl::encoding::Encoder<
12731                '_,
12732                fidl::encoding::DefaultFuchsiaResourceDialect,
12733            >,
12734            offset: usize,
12735            _depth: fidl::encoding::Depth,
12736        ) -> fidl::Result<()> {
12737            encoder.debug_check_bounds::<RunnerReceiveClosedEventsRequest>(offset);
12738            // Delegate to tuple encoding.
12739            fidl::encoding::Encode::<RunnerReceiveClosedEventsRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
12740                (
12741                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
12742                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetEventReporterMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.reporter),
12743                ),
12744                encoder, offset, _depth
12745            )
12746        }
12747    }
12748    unsafe impl<
12749            T0: fidl::encoding::Encode<
12750                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
12751                fidl::encoding::DefaultFuchsiaResourceDialect,
12752            >,
12753            T1: fidl::encoding::Encode<
12754                fidl::encoding::Endpoint<
12755                    fidl::endpoints::ClientEnd<ClosedTargetEventReporterMarker>,
12756                >,
12757                fidl::encoding::DefaultFuchsiaResourceDialect,
12758            >,
12759        >
12760        fidl::encoding::Encode<
12761            RunnerReceiveClosedEventsRequest,
12762            fidl::encoding::DefaultFuchsiaResourceDialect,
12763        > for (T0, T1)
12764    {
12765        #[inline]
12766        unsafe fn encode(
12767            self,
12768            encoder: &mut fidl::encoding::Encoder<
12769                '_,
12770                fidl::encoding::DefaultFuchsiaResourceDialect,
12771            >,
12772            offset: usize,
12773            depth: fidl::encoding::Depth,
12774        ) -> fidl::Result<()> {
12775            encoder.debug_check_bounds::<RunnerReceiveClosedEventsRequest>(offset);
12776            // Zero out padding regions. There's no need to apply masks
12777            // because the unmasked parts will be overwritten by fields.
12778            // Write the fields.
12779            self.0.encode(encoder, offset + 0, depth)?;
12780            self.1.encode(encoder, offset + 4, depth)?;
12781            Ok(())
12782        }
12783    }
12784
12785    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
12786        for RunnerReceiveClosedEventsRequest
12787    {
12788        #[inline(always)]
12789        fn new_empty() -> Self {
12790            Self {
12791                target: fidl::new_empty!(
12792                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
12793                    fidl::encoding::DefaultFuchsiaResourceDialect
12794                ),
12795                reporter: fidl::new_empty!(
12796                    fidl::encoding::Endpoint<
12797                        fidl::endpoints::ClientEnd<ClosedTargetEventReporterMarker>,
12798                    >,
12799                    fidl::encoding::DefaultFuchsiaResourceDialect
12800                ),
12801            }
12802        }
12803
12804        #[inline]
12805        unsafe fn decode(
12806            &mut self,
12807            decoder: &mut fidl::encoding::Decoder<
12808                '_,
12809                fidl::encoding::DefaultFuchsiaResourceDialect,
12810            >,
12811            offset: usize,
12812            _depth: fidl::encoding::Depth,
12813        ) -> fidl::Result<()> {
12814            decoder.debug_check_bounds::<Self>(offset);
12815            // Verify that padding bytes are zero.
12816            fidl::decode!(
12817                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<ClosedTargetMarker>>,
12818                fidl::encoding::DefaultFuchsiaResourceDialect,
12819                &mut self.target,
12820                decoder,
12821                offset + 0,
12822                _depth
12823            )?;
12824            fidl::decode!(
12825                fidl::encoding::Endpoint<
12826                    fidl::endpoints::ClientEnd<ClosedTargetEventReporterMarker>,
12827                >,
12828                fidl::encoding::DefaultFuchsiaResourceDialect,
12829                &mut self.reporter,
12830                decoder,
12831                offset + 4,
12832                _depth
12833            )?;
12834            Ok(())
12835        }
12836    }
12837
12838    impl fidl::encoding::ResourceTypeMarker for RunnerReceiveOpenEventsRequest {
12839        type Borrowed<'a> = &'a mut Self;
12840        fn take_or_borrow<'a>(
12841            value: &'a mut <Self as fidl::encoding::TypeMarker>::Owned,
12842        ) -> Self::Borrowed<'a> {
12843            value
12844        }
12845    }
12846
12847    unsafe impl fidl::encoding::TypeMarker for RunnerReceiveOpenEventsRequest {
12848        type Owned = Self;
12849
12850        #[inline(always)]
12851        fn inline_align(_context: fidl::encoding::Context) -> usize {
12852            4
12853        }
12854
12855        #[inline(always)]
12856        fn inline_size(_context: fidl::encoding::Context) -> usize {
12857            8
12858        }
12859    }
12860
12861    unsafe impl
12862        fidl::encoding::Encode<
12863            RunnerReceiveOpenEventsRequest,
12864            fidl::encoding::DefaultFuchsiaResourceDialect,
12865        > for &mut RunnerReceiveOpenEventsRequest
12866    {
12867        #[inline]
12868        unsafe fn encode(
12869            self,
12870            encoder: &mut fidl::encoding::Encoder<
12871                '_,
12872                fidl::encoding::DefaultFuchsiaResourceDialect,
12873            >,
12874            offset: usize,
12875            _depth: fidl::encoding::Depth,
12876        ) -> fidl::Result<()> {
12877            encoder.debug_check_bounds::<RunnerReceiveOpenEventsRequest>(offset);
12878            // Delegate to tuple encoding.
12879            fidl::encoding::Encode::<RunnerReceiveOpenEventsRequest, fidl::encoding::DefaultFuchsiaResourceDialect>::encode(
12880                (
12881                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.target),
12882                    <fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetEventReporterMarker>> as fidl::encoding::ResourceTypeMarker>::take_or_borrow(&mut self.reporter),
12883                ),
12884                encoder, offset, _depth
12885            )
12886        }
12887    }
12888    unsafe impl<
12889            T0: fidl::encoding::Encode<
12890                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
12891                fidl::encoding::DefaultFuchsiaResourceDialect,
12892            >,
12893            T1: fidl::encoding::Encode<
12894                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetEventReporterMarker>>,
12895                fidl::encoding::DefaultFuchsiaResourceDialect,
12896            >,
12897        >
12898        fidl::encoding::Encode<
12899            RunnerReceiveOpenEventsRequest,
12900            fidl::encoding::DefaultFuchsiaResourceDialect,
12901        > for (T0, T1)
12902    {
12903        #[inline]
12904        unsafe fn encode(
12905            self,
12906            encoder: &mut fidl::encoding::Encoder<
12907                '_,
12908                fidl::encoding::DefaultFuchsiaResourceDialect,
12909            >,
12910            offset: usize,
12911            depth: fidl::encoding::Depth,
12912        ) -> fidl::Result<()> {
12913            encoder.debug_check_bounds::<RunnerReceiveOpenEventsRequest>(offset);
12914            // Zero out padding regions. There's no need to apply masks
12915            // because the unmasked parts will be overwritten by fields.
12916            // Write the fields.
12917            self.0.encode(encoder, offset + 0, depth)?;
12918            self.1.encode(encoder, offset + 4, depth)?;
12919            Ok(())
12920        }
12921    }
12922
12923    impl fidl::encoding::Decode<Self, fidl::encoding::DefaultFuchsiaResourceDialect>
12924        for RunnerReceiveOpenEventsRequest
12925    {
12926        #[inline(always)]
12927        fn new_empty() -> Self {
12928            Self {
12929                target: fidl::new_empty!(
12930                    fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
12931                    fidl::encoding::DefaultFuchsiaResourceDialect
12932                ),
12933                reporter: fidl::new_empty!(
12934                    fidl::encoding::Endpoint<
12935                        fidl::endpoints::ClientEnd<OpenTargetEventReporterMarker>,
12936                    >,
12937                    fidl::encoding::DefaultFuchsiaResourceDialect
12938                ),
12939            }
12940        }
12941
12942        #[inline]
12943        unsafe fn decode(
12944            &mut self,
12945            decoder: &mut fidl::encoding::Decoder<
12946                '_,
12947                fidl::encoding::DefaultFuchsiaResourceDialect,
12948            >,
12949            offset: usize,
12950            _depth: fidl::encoding::Depth,
12951        ) -> fidl::Result<()> {
12952            decoder.debug_check_bounds::<Self>(offset);
12953            // Verify that padding bytes are zero.
12954            fidl::decode!(
12955                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetMarker>>,
12956                fidl::encoding::DefaultFuchsiaResourceDialect,
12957                &mut self.target,
12958                decoder,
12959                offset + 0,
12960                _depth
12961            )?;
12962            fidl::decode!(
12963                fidl::encoding::Endpoint<fidl::endpoints::ClientEnd<OpenTargetEventReporterMarker>>,
12964                fidl::encoding::DefaultFuchsiaResourceDialect,
12965                &mut self.reporter,
12966                decoder,
12967                offset + 4,
12968                _depth
12969            )?;
12970            Ok(())
12971        }
12972    }
12973}