struct OpportunitySet {
    opportunities: Vec<ThreadingOpportunity>,
    involving_tos: IndexVec<BasicBlock, Vec<(usize, usize)>>,
    predecessors: IndexVec<BasicBlock, usize>,
}Fields§
§opportunities: Vec<ThreadingOpportunity>§involving_tos: IndexVec<BasicBlock, Vec<(usize, usize)>>For each bb, give the TOs in which it appears. The pair corresponds to the index
in opportunities and the index in ThreadingOpportunity::chain.
predecessors: IndexVec<BasicBlock, usize>Cache the number of predecessors for each block, as we clear the basic block cache..
Implementations§
source§impl OpportunitySet
 
impl OpportunitySet
fn new( body: &Body<'_>, opportunities: Vec<ThreadingOpportunity> ) -> OpportunitySet
fn apply_once(&mut self, index: usize, body: &mut Body<'_>)
fn update_predecessor_count( &mut self, terminator: &Terminator<'_>, incr: Update )
Auto Trait Implementations§
impl DynSend for OpportunitySet
impl DynSync for OpportunitySet
impl Freeze for OpportunitySet
impl RefUnwindSafe for OpportunitySet
impl Send for OpportunitySet
impl Sync for OpportunitySet
impl Unpin for OpportunitySet
impl UnwindSafe for OpportunitySet
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<'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: 72 bytes