Struct rustc_trait_selection::infer::free_regions::FreeRegionMap
source · pub struct FreeRegionMap<'tcx> {
pub(crate) relation: TransitiveRelation<Region<'tcx>>,
}
Fields§
§relation: TransitiveRelation<Region<'tcx>>
Implementations§
source§impl<'tcx> FreeRegionMap<'tcx>
impl<'tcx> FreeRegionMap<'tcx>
pub fn elements(&self) -> impl Iterator<Item = Region<'tcx>>
pub fn is_empty(&self) -> bool
sourcepub fn sub_free_regions(
&self,
tcx: TyCtxt<'tcx>,
r_a: Region<'tcx>,
r_b: Region<'tcx>
) -> bool
pub fn sub_free_regions( &self, tcx: TyCtxt<'tcx>, r_a: Region<'tcx>, r_b: Region<'tcx> ) -> bool
Tests whether r_a <= r_b
.
Both regions must meet is_free_or_static
.
Subtle: one tricky case that this code gets correct is as
follows. If we know that r_b: 'static
, then this function
will return true, even though we don’t know anything that
directly relates r_a
and r_b
.
sourcepub fn lub_param_regions(
&self,
tcx: TyCtxt<'tcx>,
r_a: Region<'tcx>,
r_b: Region<'tcx>
) -> Region<'tcx>
pub fn lub_param_regions( &self, tcx: TyCtxt<'tcx>, r_a: Region<'tcx>, r_b: Region<'tcx> ) -> Region<'tcx>
Computes the least-upper-bound of two free regions. In some
cases, this is more conservative than necessary, in order to
avoid making arbitrary choices. See
TransitiveRelation::postdom_upper_bound
for more details.
Trait Implementations§
source§impl<'tcx> Clone for FreeRegionMap<'tcx>
impl<'tcx> Clone for FreeRegionMap<'tcx>
source§fn clone(&self) -> FreeRegionMap<'tcx>
fn clone(&self) -> FreeRegionMap<'tcx>
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreAuto Trait Implementations§
impl<'tcx> DynSend for FreeRegionMap<'tcx>
impl<'tcx> DynSync for FreeRegionMap<'tcx>
impl<'tcx> Freeze for FreeRegionMap<'tcx>
impl<'tcx> RefUnwindSafe for FreeRegionMap<'tcx>
impl<'tcx> Send for FreeRegionMap<'tcx>
impl<'tcx> Sync for FreeRegionMap<'tcx>
impl<'tcx> Unpin for FreeRegionMap<'tcx>
impl<'tcx> UnwindSafe for FreeRegionMap<'tcx>
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
Mutably borrows from an owned value. Read more
source§impl<T, R> CollectAndApply<T, R> for T
impl<T, R> CollectAndApply<T, R> for T
§impl<T> Filterable for T
impl<T> Filterable for T
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<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
§impl<T> Pointable for T
impl<T> Pointable for T
source§impl<'tcx, T> ToPredicate<'tcx, T> for T
impl<'tcx, T> ToPredicate<'tcx, T> for T
fn to_predicate(self, _tcx: TyCtxt<'tcx>) -> 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: 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: 128 bytes