[][src]Struct rustc_mir::borrow_check::member_constraints::MemberConstraintSet

pub(crate) struct MemberConstraintSet<'tcx, R> where
    R: Copy + Eq
{ first_constraints: FxHashMap<R, NllMemberConstraintIndex>, constraints: IndexVec<NllMemberConstraintIndex, NllMemberConstraint<'tcx>>, choice_regions: Vec<RegionVid>, }

Compactly stores a set of R0 member of [R1...Rn] constraints, indexed by the region R0.

Fields

first_constraints: FxHashMap<R, NllMemberConstraintIndex>

Stores the first "member" constraint for a given R0. This is an index into the constraints vector below.

constraints: IndexVec<NllMemberConstraintIndex, NllMemberConstraint<'tcx>>

Stores the data about each R0 member of [R1..Rn] constraint. These are organized into a linked list, so each constraint contains the index of the next constraint with the same R0.

choice_regions: Vec<RegionVid>

Stores the R1..Rn regions for all sets. For any given constraint, we keep two indices so that we can pull out a slice.

Implementations

impl<'tcx> MemberConstraintSet<'tcx, RegionVid>[src]

pub(crate) fn push_constraint(
    &mut self,
    m_c: &MemberConstraint<'tcx>,
    to_region_vid: impl FnMut(Region<'tcx>) -> RegionVid
)
[src]

Pushes a member constraint into the set.

The input member constraint m_c is in the form produced by the the rustc_middle::infer code.

The to_region_vid callback fn is used to convert the regions within into RegionVid format -- it typically consults the UniversalRegions data structure that is known to the caller (but which this code is unaware of).

impl<R1, 'tcx> MemberConstraintSet<'tcx, R1> where
    R1: Copy + Hash + Eq
[src]

pub(crate) fn into_mapped<R2>(
    self,
    map_fn: impl FnMut(R1) -> R2
) -> MemberConstraintSet<'tcx, R2> where
    R2: Copy + Hash + Eq
[src]

Remap the "member region" key using map_fn, producing a new member constraint set. This is used in the NLL code to map from the original RegionVid to an scc index. In some cases, we may have multiple R1 values mapping to the same R2 key -- that is ok, the two sets will be merged.

impl<R, 'tcx> MemberConstraintSet<'tcx, R> where
    R: Copy + Hash + Eq
[src]

pub(crate) fn all_indices(
    &self
) -> impl Iterator<Item = NllMemberConstraintIndex>
[src]

pub(crate) fn indices(
    &self,
    member_region_vid: R
) -> impl Iterator<Item = NllMemberConstraintIndex> + '_
[src]

Iterate down the constraint indices associated with a given peek-region. You can then use choice_regions and other methods to access data.

pub(crate) fn choice_regions(
    &self,
    pci: NllMemberConstraintIndex
) -> &[RegionVid]
[src]

Returns the "choice regions" for a given member constraint. This is the R1..Rn from a constraint like:

R0 member of [R1..Rn]

Trait Implementations

impl<'tcx> Default for MemberConstraintSet<'tcx, RegionVid>[src]

impl<'tcx, R> Index<NllMemberConstraintIndex> for MemberConstraintSet<'tcx, R> where
    R: Copy + Eq
[src]

type Output = NllMemberConstraint<'tcx>

The returned type after indexing.

Auto Trait Implementations

impl<'tcx, R> !RefUnwindSafe for MemberConstraintSet<'tcx, R>

impl<'tcx, R> !Send for MemberConstraintSet<'tcx, R>

impl<'tcx, R> !Sync for MemberConstraintSet<'tcx, R>

impl<'tcx, R> Unpin for MemberConstraintSet<'tcx, R> where
    R: Unpin

impl<'tcx, R> !UnwindSafe for MemberConstraintSet<'tcx, R>

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

impl<T> WithConstness for T[src]