struct ClosureSignatures<'tcx> {
    bound_sig: PolyFnSig<'tcx>,
    liberated_sig: FnSig<'tcx>,
}

Fields§

§bound_sig: PolyFnSig<'tcx>

The signature users of the closure see.

§liberated_sig: FnSig<'tcx>

The signature within the function body. This mostly differs in the sense that lifetimes are now early bound and any opaque types from the signature expectation are overridden in case there are explicit hidden types written by the user in the closure signature.

Auto Trait Implementations§

§

impl<'tcx> !RefUnwindSafe for ClosureSignatures<'tcx>

§

impl<'tcx> Send for ClosureSignatures<'tcx>

§

impl<'tcx> Sync for ClosureSignatures<'tcx>

§

impl<'tcx> Unpin for ClosureSignatures<'tcx>

§

impl<'tcx> !UnwindSafe for ClosureSignatures<'tcx>

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<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.

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 40 bytes