Struct rustc_infer::infer::at::At [−][src]
pub struct At<'a, 'tcx> {
pub infcx: &'a InferCtxt<'a, 'tcx>,
pub cause: &'a ObligationCause<'tcx>,
pub param_env: ParamEnv<'tcx>,
}
Fields
infcx: &'a InferCtxt<'a, 'tcx>
cause: &'a ObligationCause<'tcx>
param_env: ParamEnv<'tcx>
Implementations
pub fn eq_impl_headers(
self,
expected: &ImplHeader<'tcx>,
actual: &ImplHeader<'tcx>
) -> InferResult<'tcx, ()>
pub fn eq_impl_headers(
self,
expected: &ImplHeader<'tcx>,
actual: &ImplHeader<'tcx>
) -> InferResult<'tcx, ()>
Hacky routine for equating two impl headers in coherence.
Makes a <: b
, where a
may or may not be expected.
Makes actual <: expected
. For example, if type-checking a
call like foo(x)
, where foo: fn(i32)
, you might have
sup(i32, x)
, since the “expected” type is the type that
appears in the signature.
Makes expected <: actual
.
Makes expected <: actual
.
Makes expected <: actual
.
pub fn relate<T>(
self,
expected: T,
variance: Variance,
actual: T
) -> InferResult<'tcx, ()> where
T: ToTrace<'tcx>,
Computes the least-upper-bound, or mutual supertype, of two values. The order of the arguments doesn’t matter, but since this can result in an error (e.g., if asked to compute LUB of u32 and i32), it is meaningful to call one of them the “expected type”.
Computes the greatest-lower-bound, or mutual subtype, of two
values. As with lub
order doesn’t matter, except for error
cases.
Sets the “trace” values that will be used for error-reporting, but doesn’t actually perform any operation yet (this is useful when you want to set the trace using distinct values from those you wish to operate upon).
Auto Trait Implementations
impl<'a, 'tcx> !RefUnwindSafe for At<'a, 'tcx>
impl<'a, 'tcx> !UnwindSafe for At<'a, 'tcx>
Blanket Implementations
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: 24 bytes