pub trait HandleBased: AsHandleRef + From<Handle> + Into<Handle> {
    // Provided methods
    fn duplicate_handle(&self, rights: Rights) -> Result<Self, Status> { ... }
    fn replace_handle(self, rights: Rights) -> Result<Self, Status> { ... }
    fn into_handle(self) -> Handle { ... }
    fn into_raw(self) -> u32 { ... }
    fn from_handle(handle: Handle) -> Self { ... }
    fn into_handle_based<H>(self) -> H
       where H: HandleBased { ... }
    fn from_handle_based<H>(h: H) -> Self
       where H: HandleBased { ... }
    fn is_invalid_handle(&self) -> bool { ... }
}
Expand description

A trait implemented by all handle-based types.

Note: it is reasonable for user-defined objects wrapping a handle to implement this trait. For example, a specific interface in some protocol might be represented as a newtype of Channel, and implement the as_handle_ref method and the From<Handle> trait to facilitate conversion from and to the interface.

Provided Methods§

fn duplicate_handle(&self, rights: Rights) -> Result<Self, Status>

Duplicate a handle, possibly reducing the rights available. Wraps the zx_handle_duplicate syscall.

fn replace_handle(self, rights: Rights) -> Result<Self, Status>

Create a replacement for a handle, possibly reducing the rights available. This invalidates the original handle. Wraps the zx_handle_replace syscall.

fn into_handle(self) -> Handle

Converts the value into its inner handle.

This is a convenience function which simply forwards to the Into trait.

fn into_raw(self) -> u32

Converts the handle into it’s raw representation.

The caller takes ownership over the raw handle, and must close or transfer it to avoid a handle leak.

fn from_handle(handle: Handle) -> Self

Creates an instance of this type from a handle.

This is a convenience function which simply forwards to the From trait.

fn into_handle_based<H>(self) -> H
where H: HandleBased,

Creates an instance of another handle-based type from this value’s inner handle.

fn from_handle_based<H>(h: H) -> Self
where H: HandleBased,

Creates an instance of this type from the inner handle of another handle-based type.

fn is_invalid_handle(&self) -> bool

Object Safety§

This trait is not object safe.

Implementors§

source§

impl HandleBased for fidl::handle::fuchsia_handles::Bti

§

impl HandleBased for Channel

§

impl HandleBased for Clock

§

impl HandleBased for DebugLog

§

impl HandleBased for Event

§

impl HandleBased for EventPair

source§

impl HandleBased for fidl::handle::fuchsia_handles::Exception

§

impl HandleBased for Fifo

§

impl HandleBased for Guest

§

impl HandleBased for Handle

§

impl HandleBased for Interrupt

source§

impl HandleBased for fidl::handle::fuchsia_handles::Iommu

§

impl HandleBased for Job

source§

impl HandleBased for Msi

source§

impl HandleBased for fidl::handle::fuchsia_handles::Pager

source§

impl HandleBased for PciDevice

source§

impl HandleBased for fidl::handle::fuchsia_handles::Pmt

§

impl HandleBased for Port

§

impl HandleBased for Process

§

impl HandleBased for Profile

§

impl HandleBased for Resource

§

impl HandleBased for Socket

§

impl HandleBased for Stream

source§

impl HandleBased for SuspendToken

§

impl HandleBased for Thread

§

impl HandleBased for Timer

§

impl HandleBased for Vcpu

§

impl HandleBased for Vmar

§

impl HandleBased for Vmo

§

impl HandleBased for Bti

§

impl HandleBased for Exception

§

impl HandleBased for Iommu

§

impl HandleBased for Pager

§

impl HandleBased for Pmt

source§

impl<T> HandleBased for ClientEnd<T>

source§

impl<T> HandleBased for ServerEnd<T>