pub struct StrongRc<T> { /* private fields */ }
Expand description
A strongly-held reference.
Similar to an alloc::sync::Arc
but holding a Strong
acts as a witness
to the live-ness of the underlying data. That is, holding a Strong
implies
that the underlying data has not yet been destroyed.
Note that Strong
’s implementation of Hash
and PartialEq
operate on
the pointer itself and not the underlying data.
Implementations§
Source§impl<T> Strong<T>
impl<T> Strong<T>
Sourcepub fn downgrade(_: &Strong<T>) -> Weak<T>
pub fn downgrade(_: &Strong<T>) -> Weak<T>
Returns a weak reference pointing to the same underlying data.
Sourcepub fn resource_token(&self) -> ResourceToken<'_>
pub fn resource_token(&self) -> ResourceToken<'_>
Returns a ResourceToken
that corresponds to this object.
Sourcepub fn marked_for_destruction(_: &Strong<T>) -> bool
pub fn marked_for_destruction(_: &Strong<T>) -> bool
Returns true if the inner value has since been marked for destruction.
Sourcepub fn weak_ptr_eq(_: &Strong<T>, _: &Weak<T>) -> bool
pub fn weak_ptr_eq(_: &Strong<T>, _: &Weak<T>) -> bool
Returns true if the two pointers point to the same allocation.
Sourcepub fn ptr_eq(_: &Strong<T>, _: &Strong<T>) -> bool
pub fn ptr_eq(_: &Strong<T>, _: &Strong<T>) -> bool
Returns true if the two pointers point to the same allocation.
Sourcepub fn debug_references(this: &Strong<T>) -> DebugReferences<T>
pub fn debug_references(this: &Strong<T>) -> DebugReferences<T>
Creates a DebugReferences
instance.
Trait Implementations§
impl<T> Eq for Strong<T>
Auto Trait Implementations§
impl<T> Freeze for Strong<T>
impl<T> RefUnwindSafe for Strong<T>where
T: RefUnwindSafe,
impl<T> Send for Strong<T>
impl<T> Sync for Strong<T>
impl<T> Unpin for Strong<T>
impl<T> UnwindSafe for Strong<T>where
T: RefUnwindSafe,
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§impl<T, A> DynAccess<T> for A
impl<T, A> DynAccess<T> for A
Source§fn load(&self) -> DynGuard<T>
fn load(&self) -> DynGuard<T>
The equivalent of
Access::load
.§impl<T, D> Encode<Ambiguous1, D> for Twhere
D: ResourceDialect,
impl<T, D> Encode<Ambiguous1, D> for Twhere
D: ResourceDialect,
§impl<T, D> Encode<Ambiguous2, D> for Twhere
D: ResourceDialect,
impl<T, D> Encode<Ambiguous2, D> for Twhere
D: ResourceDialect,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.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<S> MapDerefExt for Swhere
S: Deref,
impl<S> MapDerefExt for Swhere
S: Deref,
§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<CC, BC, Meta> RecvFrameContext<Meta, BC> for CCwhere
Meta: ReceivableFrameMeta<CC, BC>,
impl<CC, BC, Meta> RecvFrameContext<Meta, BC> for CCwhere
Meta: ReceivableFrameMeta<CC, BC>,
Source§impl<CC, BC, Meta> SendFrameContext<BC, Meta> for CCwhere
Meta: SendableFrameMeta<CC, BC>,
impl<CC, BC, Meta> SendFrameContext<BC, Meta> for CCwhere
Meta: SendableFrameMeta<CC, BC>,
Source§fn send_frame<S>(
&mut self,
bindings_ctx: &mut BC,
metadata: Meta,
frame: S,
) -> Result<(), ErrorAndSerializer<SendFrameErrorReason, S>>
fn send_frame<S>( &mut self, bindings_ctx: &mut BC, metadata: Meta, frame: S, ) -> Result<(), ErrorAndSerializer<SendFrameErrorReason, S>>
Send a frame. Read more
Source§impl<BC, S, Meta, DeviceId> SendableFrameMeta<FakeCoreCtx<S, Meta, DeviceId>, BC> for Meta
impl<BC, S, Meta, DeviceId> SendableFrameMeta<FakeCoreCtx<S, Meta, DeviceId>, BC> for Meta
Source§fn send_meta<SS>(
self,
core_ctx: &mut FakeCoreCtx<S, Meta, DeviceId>,
bindings_ctx: &mut BC,
frame: SS,
) -> Result<(), ErrorAndSerializer<SendFrameErrorReason, SS>>
fn send_meta<SS>( self, core_ctx: &mut FakeCoreCtx<S, Meta, DeviceId>, bindings_ctx: &mut BC, frame: SS, ) -> Result<(), ErrorAndSerializer<SendFrameErrorReason, SS>>
Sends this frame metadata to the provided contexts.
Source§impl<Meta, BC> SendableFrameMeta<FakeFrameCtx<Meta>, BC> for Meta
impl<Meta, BC> SendableFrameMeta<FakeFrameCtx<Meta>, BC> for Meta
Source§fn send_meta<S>(
self,
core_ctx: &mut FakeFrameCtx<Meta>,
_bindings_ctx: &mut BC,
frame: S,
) -> Result<(), ErrorAndSerializer<SendFrameErrorReason, S>>
fn send_meta<S>( self, core_ctx: &mut FakeFrameCtx<Meta>, _bindings_ctx: &mut BC, frame: S, ) -> Result<(), ErrorAndSerializer<SendFrameErrorReason, S>>
Sends this frame metadata to the provided contexts.
Source§impl<Id, CC, BC> TimerHandler<BC, Id> for CCwhere
BC: TimerBindingsTypes,
Id: HandleableTimer<CC, BC>,
impl<Id, CC, BC> TimerHandler<BC, Id> for CCwhere
BC: TimerBindingsTypes,
Id: HandleableTimer<CC, BC>,
Source§fn handle_timer(
&mut self,
bindings_ctx: &mut BC,
dispatch: Id,
timer: <BC as TimerBindingsTypes>::UniqueTimerId,
)
fn handle_timer( &mut self, bindings_ctx: &mut BC, dispatch: Id, timer: <BC as TimerBindingsTypes>::UniqueTimerId, )
Handle a timer firing. Read more
§impl<L, T> UnlockedAccess<L> for Twhere
L: UnlockedAccessMarkerFor<T>,
impl<L, T> UnlockedAccess<L> for Twhere
L: UnlockedAccessMarkerFor<T>,
Source§impl<N> UnreachableExt for Nwhere
N: AsRef<Infallible>,
impl<N> UnreachableExt for Nwhere
N: AsRef<Infallible>,
Source§fn uninstantiable_unreachable<T>(&self) -> T
fn uninstantiable_unreachable<T>(&self) -> T
A method that can’t be called. Read more