#[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> 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 Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere 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> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for Twhere 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 Fwhere 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 Twhere 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 Fwhere 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 Twhere 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.
source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more