Struct hir_ty::InferenceResult

source ·
pub struct InferenceResult {
    pub tuple_field_access_types: FxHashMap<TupleId, Substitution>,
    pub diagnostics: Vec<InferenceDiagnostic>,
    pub type_of_expr: ArenaMap<ExprId, Ty>,
    pub type_of_pat: ArenaMap<PatId, Ty>,
    pub type_of_binding: ArenaMap<BindingId, Ty>,
    pub type_of_rpit: ArenaMap<ImplTraitIdx, Ty>,
    pub type_of_for_iterator: FxHashMap<ExprId, Ty>,
    pub pat_adjustments: FxHashMap<PatId, Vec<Ty>>,
    pub binding_modes: ArenaMap<PatId, BindingMode>,
    pub expr_adjustments: FxHashMap<ExprId, Vec<Adjustment>>,
    pub mutated_bindings_in_closure: FxHashSet<BindingId>,
    /* private fields */
}
Expand description

The result of type inference: A mapping from expressions and patterns to types.

When you add a field that stores types (including Substitution and the like), don’t forget resolve_completely()’ing them in InferenceContext::resolve_all(). Inference variables must not appear in the final inference result.

Fields§

§tuple_field_access_types: FxHashMap<TupleId, Substitution>

Whenever a tuple field expression access a tuple field, we allocate a tuple id in [InferenceContext] and store the tuples substitution there. This map is the reverse of that which allows us to resolve a [TupleFieldId]s type.

§diagnostics: Vec<InferenceDiagnostic>§type_of_expr: ArenaMap<ExprId, Ty>§type_of_pat: ArenaMap<PatId, Ty>

For each pattern record the type it resolves to.

Note: When a pattern type is resolved it may still contain unresolved or missing subpatterns or subpatterns of mismatched types.

§type_of_binding: ArenaMap<BindingId, Ty>§type_of_rpit: ArenaMap<ImplTraitIdx, Ty>§type_of_for_iterator: FxHashMap<ExprId, Ty>

Type of the result of .into_iter() on the for. ExprId is the one of the whole for loop.

§pat_adjustments: FxHashMap<PatId, Vec<Ty>>

Stores the types which were implicitly dereferenced in pattern binding modes.

§binding_modes: ArenaMap<PatId, BindingMode>

Stores the binding mode (ref in let ref x = 2) of bindings.

This one is tied to the PatId instead of BindingId, because in some rare cases, a binding in an or pattern can have multiple binding modes. For example:

fn foo(mut slice: &[u32]) -> usize {
   slice = match slice {
       [0, rest @ ..] | rest => rest,
   };
}

the first rest has implicit ref binding mode, but the second rest binding mode is move.

§expr_adjustments: FxHashMap<ExprId, Vec<Adjustment>>§mutated_bindings_in_closure: FxHashSet<BindingId>

Implementations§

source§

impl InferenceResult

source

pub fn method_resolution( &self, expr: ExprId ) -> Option<(FunctionId, Substitution)>

source

pub fn field_resolution( &self, expr: ExprId ) -> Option<Either<FieldId, TupleFieldId>>

source

pub fn variant_resolution_for_expr(&self, id: ExprId) -> Option<VariantId>

source

pub fn variant_resolution_for_pat(&self, id: PatId) -> Option<VariantId>

source

pub fn assoc_resolutions_for_expr( &self, id: ExprId ) -> Option<(AssocItemId, Substitution)>

source

pub fn assoc_resolutions_for_pat( &self, id: PatId ) -> Option<(AssocItemId, Substitution)>

source

pub fn type_mismatch_for_expr(&self, expr: ExprId) -> Option<&TypeMismatch>

source

pub fn type_mismatch_for_pat(&self, pat: PatId) -> Option<&TypeMismatch>

source

pub fn type_mismatches( &self ) -> impl Iterator<Item = (ExprOrPatId, &TypeMismatch)>

source

pub fn expr_type_mismatches( &self ) -> impl Iterator<Item = (ExprId, &TypeMismatch)>

source

pub fn closure_info(&self, closure: &ClosureId) -> &(Vec<CapturedItem>, FnTrait)

Trait Implementations§

source§

impl Clone for InferenceResult

source§

fn clone(&self) -> InferenceResult

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for InferenceResult

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for InferenceResult

source§

fn default() -> InferenceResult

Returns the “default value” for a type. Read more
source§

impl Index<Idx<Binding>> for InferenceResult

§

type Output = Ty<Interner>

The returned type after indexing.
source§

fn index(&self, b: BindingId) -> &Ty

Performs the indexing (container[index]) operation. Read more
source§

impl Index<Idx<Expr>> for InferenceResult

§

type Output = Ty<Interner>

The returned type after indexing.
source§

fn index(&self, expr: ExprId) -> &Ty

Performs the indexing (container[index]) operation. Read more
source§

impl Index<Idx<Pat>> for InferenceResult

§

type Output = Ty<Interner>

The returned type after indexing.
source§

fn index(&self, pat: PatId) -> &Ty

Performs the indexing (container[index]) operation. Read more
source§

impl PartialEq for InferenceResult

source§

fn eq(&self, other: &InferenceResult) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Eq for InferenceResult

source§

impl StructuralPartialEq for InferenceResult

Auto Trait Implementations§

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
§

impl<T> Cast for T

§

fn cast<U>(self, interner: <U as HasInterner>::Interner) -> U
where Self: CastTo<U>, U: HasInterner,

Cast a value to type U using CastTo.
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

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

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

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

§

impl<T> IntoBox<dyn Any> for T
where T: Any,

§

fn into_box(self) -> Box<dyn Any>

Convert self into the appropriate boxed form.
§

impl<T> IntoBox<dyn Any + Send> for T
where T: Any + Send,

§

fn into_box(self) -> Box<dyn Any + Send>

Convert self into the appropriate boxed form.
§

impl<T> IntoBox<dyn Any + Send + Sync> for T
where T: Any + Send + Sync,

§

fn into_box(self) -> Box<dyn Any + Send + Sync>

Convert self into the appropriate boxed form.
§

impl<T> IntoBox<dyn CloneAny> for T
where T: CloneAny,

§

fn into_box(self) -> Box<dyn CloneAny>

Convert self into the appropriate boxed form.
§

impl<T> IntoBox<dyn CloneAny + Send> for T
where T: CloneAny + Send,

§

fn into_box(self) -> Box<dyn CloneAny + Send>

Convert self into the appropriate boxed form.
§

impl<T> IntoBox<dyn CloneAny + Send + Sync> for T
where T: CloneAny + Send + Sync,

§

fn into_box(self) -> Box<dyn CloneAny + Send + Sync>

Convert self into the appropriate boxed form.
source§

impl<T> IntoEither for T

source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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 more
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. 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<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.
§

impl<T> WithSubscriber for T

§

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
§

fn with_current_subscriber(self) -> WithDispatch<Self>

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

impl<'a, T> Captures<'a> for T
where T: ?Sized,

§

impl<T> CloneAny for T
where T: Any + Clone,