pub struct CoroutineArgsParts<I>where
I: Interner,{
pub parent_args: <I as Interner>::GenericArgsSlice,
pub kind_ty: <I as Interner>::Ty,
pub resume_ty: <I as Interner>::Ty,
pub yield_ty: <I as Interner>::Ty,
pub return_ty: <I as Interner>::Ty,
pub witness: <I as Interner>::Ty,
pub tupled_upvars_ty: <I as Interner>::Ty,
}
Fields§
§parent_args: <I as Interner>::GenericArgsSlice
This is the args of the typeck root.
kind_ty: <I as Interner>::Ty
The coroutines returned by a coroutine-closure’s AsyncFnOnce
/AsyncFnMut
implementations must be distinguished since the former takes the closure’s
upvars by move, and the latter takes the closure’s upvars by ref.
This field distinguishes these fields so that codegen can select the right
body for the coroutine. This has the same type representation as the closure
kind: i8
/i16
/i32
.
For regular coroutines, this field will always just be ()
.
resume_ty: <I as Interner>::Ty
§yield_ty: <I as Interner>::Ty
§return_ty: <I as Interner>::Ty
§witness: <I as Interner>::Ty
The interior type of the coroutine. Represents all types that are stored in locals in the coroutine’s body.
tupled_upvars_ty: <I as Interner>::Ty
The upvars captured by the closure. Remains an inference variable until the upvar analysis, which happens late in HIR typeck.
Auto Trait Implementations§
impl<I> Freeze for CoroutineArgsParts<I>
impl<I> RefUnwindSafe for CoroutineArgsParts<I>
impl<I> Send for CoroutineArgsParts<I>
impl<I> Sync for CoroutineArgsParts<I>
impl<I> Unpin for CoroutineArgsParts<I>
impl<I> UnwindSafe for CoroutineArgsParts<I>
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
source§impl<T, R> CollectAndApply<T, R> for T
impl<T, R> CollectAndApply<T, R> for T
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>
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>
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>
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<P> IntoQueryParam<P> for P
impl<P> IntoQueryParam<P> for P
fn into_query_param(self) -> P
source§impl<T> MaybeResult<T> for T
impl<T> MaybeResult<T> for T
source§impl<I, T, U> Upcast<I, U> for Twhere
U: UpcastFrom<I, T>,
impl<I, T, U> Upcast<I, U> for Twhere
U: UpcastFrom<I, T>,
source§impl<I, T> UpcastFrom<I, T> for T
impl<I, T> UpcastFrom<I, T> for T
fn upcast_from(from: T, _tcx: I) -> T
source§impl<Tcx, T> Value<Tcx> for Twhere
Tcx: DepContext,
impl<Tcx, T> Value<Tcx> for Twhere
Tcx: DepContext,
default fn from_cycle_error( tcx: Tcx, cycle_error: &CycleError, _guar: ErrorGuaranteed, ) -> T
source§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
source§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
source§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
impl<'a, T> Captures<'a> for Twhere
T: ?Sized,
impl<T> ErasedDestructor for Twhere
T: 'static,
impl<T> MaybeSendSync for T
Layout§
Note: Unable to compute type layout, possibly due to this type having generic parameters. Layout can only be computed for concrete, fully-instantiated types.