Struct rustc_infer::infer::region_constraints::leak_check::LeakCheck
source · struct LeakCheck<'a, 'b, 'tcx> {
tcx: TyCtxt<'tcx>,
outer_universe: UniverseIndex,
mini_graph: &'a MiniGraph<'tcx>,
rcc: &'a mut RegionConstraintCollector<'b, 'tcx>,
scc_placeholders: IndexVec<LeakCheckScc, Option<PlaceholderRegion>>,
scc_universes: IndexVec<LeakCheckScc, SccUniverse<'tcx>>,
}
Fields§
§tcx: TyCtxt<'tcx>
§outer_universe: UniverseIndex
§mini_graph: &'a MiniGraph<'tcx>
§rcc: &'a mut RegionConstraintCollector<'b, 'tcx>
§scc_placeholders: IndexVec<LeakCheckScc, Option<PlaceholderRegion>>
§scc_universes: IndexVec<LeakCheckScc, SccUniverse<'tcx>>
Implementations§
source§impl<'a, 'b, 'tcx> LeakCheck<'a, 'b, 'tcx>
impl<'a, 'b, 'tcx> LeakCheck<'a, 'b, 'tcx>
fn new( tcx: TyCtxt<'tcx>, outer_universe: UniverseIndex, max_universe: UniverseIndex, mini_graph: &'a MiniGraph<'tcx>, rcc: &'a mut RegionConstraintCollector<'b, 'tcx> ) -> Self
sourcefn assign_placeholder_values(&mut self) -> RelateResult<'tcx, ()>
fn assign_placeholder_values(&mut self) -> RelateResult<'tcx, ()>
Compute what placeholders (if any) each SCC must be equal to. Also compute the minimum universe of all the regions in each SCC.
fn assign_scc_value( &mut self, scc: LeakCheckScc, placeholder: PlaceholderRegion ) -> RelateResult<'tcx, ()>
sourcefn propagate_scc_value(&mut self) -> RelateResult<'tcx, ()>
fn propagate_scc_value(&mut self) -> RelateResult<'tcx, ()>
For each SCC S, iterate over each successor S1 where S: S1
:
- Compute
Iterate over each SCC
S
and ensure that, for eachS1
whereS1: S
,universe(S) <= universe(S1)
. This executes afterassign_placeholder_values
, souniverse(S)
is already the minimum universe of any of its direct constituents.
fn placeholder_error( &self, placeholder1: PlaceholderRegion, placeholder2: PlaceholderRegion ) -> TypeError<'tcx>
fn error( &self, placeholder: PlaceholderRegion, other_region: Region<'tcx> ) -> TypeError<'tcx>
Auto Trait Implementations§
impl<'a, 'b, 'tcx> DynSend for LeakCheck<'a, 'b, 'tcx>
impl<'a, 'b, 'tcx> DynSync for LeakCheck<'a, 'b, 'tcx>
impl<'a, 'b, 'tcx> Freeze for LeakCheck<'a, 'b, 'tcx>
impl<'a, 'b, 'tcx> !RefUnwindSafe for LeakCheck<'a, 'b, 'tcx>
impl<'a, 'b, 'tcx> !Send for LeakCheck<'a, 'b, 'tcx>
impl<'a, 'b, 'tcx> !Sync for LeakCheck<'a, 'b, 'tcx>
impl<'a, 'b, 'tcx> Unpin for LeakCheck<'a, 'b, 'tcx>
impl<'a, 'b, 'tcx> !UnwindSafe for LeakCheck<'a, 'b, '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,
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: 80 bytes