struct Generalizer<'cx, 'tcx> {
    infcx: &'cx InferCtxt<'cx, 'tcx>,
    cause: &'cx ObligationCause<'tcx>,
    for_vid_sub_root: TyVid,
    for_universe: UniverseIndex,
    ambient_variance: Variance,
    needs_wf: bool,
    root_ty: Ty<'tcx>,
    param_env: ParamEnv<'tcx>,
    cache: SsoHashMap<Ty<'tcx>, Ty<'tcx>>,
}

Fields

infcx: &'cx InferCtxt<'cx, 'tcx>cause: &'cx ObligationCause<'tcx>

The span, used when creating new type variables and things.

for_vid_sub_root: TyVid

The vid of the type variable that is in the process of being instantiated; if we find this within the type we are folding, that means we would have created a cyclic type.

for_universe: UniverseIndex

The universe of the type variable that is in the process of being instantiated. Any fresh variables that we create in this process should be in that same universe.

ambient_variance: Variance

Track the variance as we descend into the type.

needs_wf: bool

See the field needs_wf in Generalization.

root_ty: Ty<'tcx>

The root type that we are generalizing. Used when reporting cycles.

param_env: ParamEnv<'tcx>cache: SsoHashMap<Ty<'tcx>, Ty<'tcx>>

Trait Implementations

Returns a static string we can use for printouts.
Returns true if the value a is the “expected” type in the relation. Just affects error messages. Read more
Relate the two substitutions for the given item. The default is to look up the variance for the item and proceed accordingly. Read more
Switch variance for the purpose of relating a and b.
Generic relation routine suitable for most anything.

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more
Immutably borrows from an owned value. Read more
Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

The type returned in the event of a conversion error.
Performs the conversion.
The type returned in the event of a conversion 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: 192 bytes