Struct fidl_fuchsia_fuzzer::RegistryProxy
source · pub struct RegistryProxy { /* private fields */ }
Implementations§
source§impl RegistryProxy
impl RegistryProxy
sourcepub fn new(channel: AsyncChannel) -> Self
pub fn new(channel: AsyncChannel) -> Self
Create a new Proxy for fuchsia.fuzzer/Registry.
sourcepub fn take_event_stream(&self) -> RegistryEventStream
pub fn take_event_stream(&self) -> RegistryEventStream
Get a Stream of events from the remote end of the protocol.
§Panics
Panics if the event stream was already taken.
sourcepub fn connect(
&self,
fuzzer_url: &str,
controller: ServerEnd<ControllerMarker>,
timeout: i64,
) -> QueryResponseFut<RegistryConnectResult>
pub fn connect( &self, fuzzer_url: &str, controller: ServerEnd<ControllerMarker>, timeout: i64, ) -> QueryResponseFut<RegistryConnectResult>
Connects the Controller
to a registered fuzzer.
Uses a ControllerProvider
that has been Register
ed with the given
URL to connect. If the associated provider is not available, it assumes
it is starting and blocks until the fuzzer calls Registrar.Register
,
or the given timeout
elapses. At most one call to Connect
will block
in this manner at a time.
- request
fuzzer_url
the package URL for the fuzzer. - request
provider
the connection to aController
client. - request
tiemout
maximum duration to wait for a connection.
- error one of the following:
ZX_ERR_TIMED_OUT
if thetimeout
elapses without the provider becoming available.ZX_ERR_SHOULD_WAIT
if already waiting for a fuzzer to start.
sourcepub fn disconnect(
&self,
fuzzer_url: &str,
) -> QueryResponseFut<RegistryDisconnectResult>
pub fn disconnect( &self, fuzzer_url: &str, ) -> QueryResponseFut<RegistryDisconnectResult>
Removes the provider associated with the given URL from the registry and closes its channel. The associated fuzzer should exit upon channel closure.
- request
fuzzer_url
the package URL for the fuzzer.
- error
ZX_ERR_NOT_FOUND
if no such provider exists in the registry.
Trait Implementations§
source§impl Clone for RegistryProxy
impl Clone for RegistryProxy
source§fn clone(&self) -> RegistryProxy
fn clone(&self) -> RegistryProxy
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moresource§impl Debug for RegistryProxy
impl Debug for RegistryProxy
source§impl Proxy for RegistryProxy
impl Proxy for RegistryProxy
§type Protocol = RegistryMarker
type Protocol = RegistryMarker
The protocol which this
Proxy
controls.source§fn from_channel(inner: AsyncChannel) -> Self
fn from_channel(inner: AsyncChannel) -> Self
Create a proxy over the given channel.
source§fn into_channel(self) -> Result<AsyncChannel, Self>
fn into_channel(self) -> Result<AsyncChannel, Self>
Attempt to convert the proxy back into a channel. Read more
source§fn as_channel(&self) -> &AsyncChannel
fn as_channel(&self) -> &AsyncChannel
Get a reference to the proxy’s underlying channel. Read more
source§impl RegistryProxyInterface for RegistryProxy
impl RegistryProxyInterface for RegistryProxy
type ConnectResponseFut = QueryResponseFut<Result<(), i32>>
fn connect( &self, fuzzer_url: &str, controller: ServerEnd<ControllerMarker>, timeout: i64, ) -> Self::ConnectResponseFut
type DisconnectResponseFut = QueryResponseFut<Result<(), i32>>
fn disconnect(&self, fuzzer_url: &str) -> Self::DisconnectResponseFut
Auto Trait Implementations§
impl Freeze for RegistryProxy
impl !RefUnwindSafe for RegistryProxy
impl Send for RegistryProxy
impl Sync for RegistryProxy
impl Unpin for RegistryProxy
impl !UnwindSafe for RegistryProxy
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§default unsafe fn clone_to_uninit(&self, dst: *mut T)
default unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)