Struct tokio_util::util::maybe_dangling::MaybeDangling

source ·
#[repr(transparent)]
pub(crate) struct MaybeDangling<T>(MaybeUninit<T>);
Expand description

A wrapper type that tells the compiler that the contents might not be valid.

This is necessary mainly when T contains a reference. In that case, the compiler will sometimes assume that the reference is always valid; in some cases it will assume this even after the destructor of T runs. For example, when a reference is used as a function argument, then the compiler will assume that the reference is valid until the function returns, even if the reference is destroyed during the function. When the reference is used as part of a self-referential struct, that assumption can be false. Wrapping the reference in this type prevents the compiler from making that assumption.

§Invariants

The MaybeUninit will always contain a valid value until the destructor runs.

Tuple Fields§

§0: MaybeUninit<T>

Implementations§

source§

impl<T> MaybeDangling<T>

source

pub(crate) fn new(inner: T) -> Self

Trait Implementations§

source§

impl<T> Drop for MaybeDangling<T>

source§

fn drop(&mut self)

Executes the destructor for this type. Read more
source§

impl<F: Future> Future for MaybeDangling<F>

§

type Output = <F as Future>::Output

The type of value produced on completion.
source§

fn poll(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Self::Output>

Attempt to resolve the future to a final value, registering the current task for wakeup if the value is not yet available. Read more

Auto Trait Implementations§

§

impl<T> Freeze for MaybeDangling<T>
where T: Freeze,

§

impl<T> RefUnwindSafe for MaybeDangling<T>
where T: RefUnwindSafe,

§

impl<T> Send for MaybeDangling<T>
where T: Send,

§

impl<T> Sync for MaybeDangling<T>
where T: Sync,

§

impl<T> Unpin for MaybeDangling<T>
where T: Unpin,

§

impl<T> UnwindSafe for MaybeDangling<T>
where T: UnwindSafe,

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> 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<F> IntoFuture for F
where F: Future,

§

type Output = <F as Future>::Output

The output that the future will produce on completion.
§

type IntoFuture = F

Which kind of future are we turning this into?
source§

fn into_future(self) -> <F as IntoFuture>::IntoFuture

Creates a future from a value. 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<F, T, E> TryFuture for F
where F: Future<Output = Result<T, E>> + ?Sized,

§

type Ok = T

The type of successful values yielded by this future
§

type Error = E

The type of failures yielded by this future
source§

fn try_poll( self: Pin<&mut F>, cx: &mut Context<'_>, ) -> Poll<<F as Future>::Output>

Poll this TryFuture as if it were a Future. Read more
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.