Struct windows_core::InterfaceRef

pub struct InterfaceRef<'a, I>(/* private fields */);
Expand description

This has the same memory representation as IFoo, but represents a borrowed interface pointer.

This type has no Drop impl; it does not AddRef/Release the given interface. However, because it has a lifetime parameter, it always represents a non-null pointer to an interface.

Implementations§

§

impl<'a, I: Interface> InterfaceRef<'a, I>

pub unsafe fn from_raw(ptr: NonNull<c_void>) -> Self

Creates an InterfaceRef from a raw pointer. This is extremely dangerous, since there is no lifetime tracking at all!

§Safety

The caller must guarantee that the 'a lifetime parameter is bound by context to a correct lifetime.

pub fn from_interface(interface: &I) -> Self

Creates an InterfaceRef from an interface reference. This safely associates the lifetime of the interface reference with the 'a parameter of InterfaceRef. This allows for lifetime checking without calling AddRef/Release on the underlying lifetime, which can improve efficiency.

pub fn to_owned(self) -> I

Calls AddRef on the underlying COM interface and returns an “owned” (counted) reference.

Trait Implementations§

§

impl<'a, I> Clone for InterfaceRef<'a, I>

§

fn clone(&self) -> Self

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
§

impl<'a, I: Debug + Interface> Debug for InterfaceRef<'a, I>

§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
§

impl<'a, I: Interface> Deref for InterfaceRef<'a, I>

§

type Target = I

The resulting type after dereferencing.
§

fn deref(&self) -> &I

Dereferences the value.
§

impl<'a, 'i: 'a, I: Interface> From<&'i I> for InterfaceRef<'a, I>

§

fn from(interface: &'a I) -> InterfaceRef<'a, I>

Converts to this type from the input type.
§

impl<'a, I> Copy for InterfaceRef<'a, I>

Auto Trait Implementations§

§

impl<'a, I> Freeze for InterfaceRef<'a, I>

§

impl<'a, I> RefUnwindSafe for InterfaceRef<'a, I>
where I: RefUnwindSafe,

§

impl<'a, I> !Send for InterfaceRef<'a, I>

§

impl<'a, I> !Sync for InterfaceRef<'a, I>

§

impl<'a, I> Unpin for InterfaceRef<'a, I>

§

impl<'a, I> UnwindSafe for InterfaceRef<'a, I>
where I: RefUnwindSafe,

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> CloneToUninit for T
where T: Copy,

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> CloneToUninit for T
where T: Clone,

source§

default unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.