Struct fidl_fuchsia_device::ControllerProxy
source · pub struct ControllerProxy { /* private fields */ }
Implementations§
source§impl ControllerProxy
impl ControllerProxy
sourcepub fn take_event_stream(&self) -> ControllerEventStream
pub fn take_event_stream(&self) -> ControllerEventStream
Get a Stream of events from the remote end of the protocol.
§Panics
Panics if the event stream was already taken.
sourcepub fn connect_to_device_fidl(&self, server: Channel) -> Result<(), Error>
pub fn connect_to_device_fidl(&self, server: Channel) -> Result<(), Error>
Connect to the underlying device’s FIDL protocol. This connection will not be multiplexed with fuchsia.device.Controller or fuchsia.io.Node.
sourcepub fn connect_to_controller(
&self,
server: ServerEnd<ControllerMarker>,
) -> Result<(), Error>
pub fn connect_to_controller( &self, server: ServerEnd<ControllerMarker>, ) -> Result<(), Error>
Connect to the same Controller FIDL protocol.
sourcepub fn bind(&self, driver: &str) -> QueryResponseFut<ControllerBindResult>
pub fn bind(&self, driver: &str) -> QueryResponseFut<ControllerBindResult>
Attempt to bind a driver to this device.
- request
driver
This represents the suffix of a driver URL (e.g: “fvm.cm”). If this is non-empty, then the only drivers that will try to bind are ones that match this url suffix.
sourcepub fn rebind(&self, driver: &str) -> QueryResponseFut<ControllerRebindResult>
pub fn rebind(&self, driver: &str) -> QueryResponseFut<ControllerRebindResult>
Unbind all the children of this device, and then attempt to bind a driver to the device. This will not return until the bind completes.
- request
driver
This represents the suffix of a driver URL (e.g: “fvm.cm”). If this is non-empty, then the only drivers that will try to bind are ones that match this url suffix.
sourcepub fn unbind_children(
&self,
) -> QueryResponseFut<ControllerUnbindChildrenResult>
pub fn unbind_children( &self, ) -> QueryResponseFut<ControllerUnbindChildrenResult>
This api will unbind all the children of this device synchronously. This will avoid watching for device removal by the clients.
sourcepub fn schedule_unbind(
&self,
) -> QueryResponseFut<ControllerScheduleUnbindResult>
pub fn schedule_unbind( &self, ) -> QueryResponseFut<ControllerScheduleUnbindResult>
Disconnect this device and allow its parent to be bound again. This may not complete before it returns.
sourcepub fn get_topological_path(
&self,
) -> QueryResponseFut<ControllerGetTopologicalPathResult>
pub fn get_topological_path( &self, ) -> QueryResponseFut<ControllerGetTopologicalPathResult>
Return the topological path for this device
Trait Implementations§
source§impl Clone for ControllerProxy
impl Clone for ControllerProxy
source§fn clone(&self) -> ControllerProxy
fn clone(&self) -> ControllerProxy
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 ControllerProxyInterface for ControllerProxy
impl ControllerProxyInterface for ControllerProxy
fn connect_to_device_fidl(&self, server: Channel) -> Result<(), Error>
fn connect_to_controller( &self, server: ServerEnd<ControllerMarker>, ) -> Result<(), Error>
type BindResponseFut = QueryResponseFut<Result<(), i32>>
fn bind(&self, driver: &str) -> Self::BindResponseFut
type RebindResponseFut = QueryResponseFut<Result<(), i32>>
fn rebind(&self, driver: &str) -> Self::RebindResponseFut
type UnbindChildrenResponseFut = QueryResponseFut<Result<(), i32>>
fn unbind_children(&self) -> Self::UnbindChildrenResponseFut
type ScheduleUnbindResponseFut = QueryResponseFut<Result<(), i32>>
fn schedule_unbind(&self) -> Self::ScheduleUnbindResponseFut
type GetTopologicalPathResponseFut = QueryResponseFut<Result<String, i32>>
fn get_topological_path(&self) -> Self::GetTopologicalPathResponseFut
source§impl Debug for ControllerProxy
impl Debug for ControllerProxy
source§impl Proxy for ControllerProxy
impl Proxy for ControllerProxy
§type Protocol = ControllerMarker
type Protocol = ControllerMarker
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
§fn into_client_end(self) -> Result<ClientEnd<Self::Protocol>, Self>
fn into_client_end(self) -> Result<ClientEnd<Self::Protocol>, Self>
Attempt to convert the proxy back into a client end. Read more
Auto Trait Implementations§
impl Freeze for ControllerProxy
impl !RefUnwindSafe for ControllerProxy
impl Send for ControllerProxy
impl Sync for ControllerProxy
impl Unpin for ControllerProxy
impl !UnwindSafe for ControllerProxy
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
)