#[repr(C)]pub struct already_AddRefed<T> {
pub mRawPtr: *mut T,
pub _phantom_0: PhantomData<UnsafeCell<T>>,
}
Expand description
already_AddRefed cooperates with reference counting smart pointers to enable you to assign in a pointer without |AddRef|ing it. You might want to use this as a return type from a function that returns an already |AddRef|ed pointer. Or, you might want to use this as a parameter type in a function that wants to force a transfer-of-ownership from a RefPtr in the caller (for example, if the function expects callers to pass in a newly-created object, which the function then takes ownership of).
TODO Move already_AddRefed to namespace mozilla. This has not yet been done because of the sheer number of usages of already_AddRefed.
When should you use already_AddRefed<>?
- Ensure a consumer takes ownership of a reference
- Pass ownership without calling AddRef/Release (sometimes required in off-main-thread code)
- The ref pointer type you’re using doesn’t support move construction
Otherwise, use std::move(RefPtr/nsCOMPtr/etc).
Fields§
§mRawPtr: *mut T
§_phantom_0: PhantomData<UnsafeCell<T>>
Trait Implementations§
source§impl<T> Debug for already_AddRefed<T>where
T: Debug,
impl<T> Debug for already_AddRefed<T>where
T: Debug,
source§impl<T> PartialEq for already_AddRefed<T>where
T: PartialEq,
impl<T> PartialEq for already_AddRefed<T>where
T: PartialEq,
source§fn eq(&self, other: &already_AddRefed<T>) -> bool
fn eq(&self, other: &already_AddRefed<T>) -> bool
This method tests for
self
and other
values to be equal, and is used
by ==
.impl<T> StructuralPartialEq for already_AddRefed<T>
Auto Trait Implementations§
impl<T> Freeze for already_AddRefed<T>
impl<T> !RefUnwindSafe for already_AddRefed<T>
impl<T> !Send for already_AddRefed<T>
impl<T> !Sync for already_AddRefed<T>
impl<T> Unpin for already_AddRefed<T>where
T: Unpin,
impl<T> UnwindSafe for already_AddRefed<T>where
T: RefUnwindSafe + UnwindSafe,
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> Filterable for T
impl<T> Filterable for T
source§fn filterable(
self,
filter_name: &'static str,
) -> RequestFilterDataProvider<T, fn(_: DataRequest<'_>) -> bool>
fn filterable( self, filter_name: &'static str, ) -> RequestFilterDataProvider<T, fn(_: DataRequest<'_>) -> bool>
Creates a filterable data provider with the given name for debugging. Read more
source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§impl<T> MaybeBoxed<Box<T>> for T
impl<T> MaybeBoxed<Box<T>> for T
source§fn maybe_boxed(self) -> Box<T>
fn maybe_boxed(self) -> Box<T>
Convert
source§impl<T> MaybeBoxed<T> for T
impl<T> MaybeBoxed<T> for T
source§fn maybe_boxed(self) -> T
fn maybe_boxed(self) -> T
Convert