Struct rustc_mir_transform::coverage::graph::BasicCoverageBlockData   
source · pub(crate) struct BasicCoverageBlockData {
    pub(crate) basic_blocks: Vec<BasicBlock>,
}Expand description
BasicCoverageBlockData holds the data indexed by a BasicCoverageBlock.
A BasicCoverageBlock (BCB) represents the maximal-length sequence of MIR BasicBlocks without
conditional branches, and form a new, simplified, coverage-specific Control Flow Graph, without
altering the original MIR CFG.
Note that running the MIR SimplifyCfg transform is not sufficient (and therefore not
necessary). The BCB-based CFG is a more aggressive simplification. For example:
- The BCB CFG ignores (trims) branches not relevant to coverage, such as unwind-related code,
that is injected by the Rust compiler but has no physical source code to count. This also
means a BasicBlock with a Callterminator can be merged into its primary successor target block, in the same BCB. (But, note: Issue #78544: “MIR InstrumentCoverage: Improve coverage of#[should_panic]tests andcatch_unwind()handlers”)
- Some BasicBlock terminators support Rust-specific concerns–like borrow-checking–that are
not relevant to coverage analysis. FalseUnwind, for example, can be treated the same as aGoto, and merged with its successor into the same BCB.
Each BCB with at least one computed coverage span will have no more than one Counter.
In some cases, a BCB’s execution count can be computed by Expression. Additional
disjoint coverage spans in a BCB can also be counted by Expression (by adding ZERO
to the BCB’s primary counter or expression).
The BCB CFG is critical to simplifying the coverage analysis by ensuring graph path-based
queries (dominates(), predecessors, successors, etc.) have branch (control flow)
significance.
Fields§
§basic_blocks: Vec<BasicBlock>Implementations§
source§impl BasicCoverageBlockData
 
impl BasicCoverageBlockData
fn from(basic_blocks: Vec<BasicBlock>) -> Self
pub(crate) fn leader_bb(&self) -> BasicBlock
pub(crate) fn last_bb(&self) -> BasicBlock
Trait Implementations§
source§impl Clone for BasicCoverageBlockData
 
impl Clone for BasicCoverageBlockData
source§fn clone(&self) -> BasicCoverageBlockData
 
fn clone(&self) -> BasicCoverageBlockData
1.0.0 · source§fn clone_from(&mut self, source: &Self)
 
fn clone_from(&mut self, source: &Self)
source. Read moreAuto Trait Implementations§
impl DynSend for BasicCoverageBlockData
impl DynSync for BasicCoverageBlockData
impl Freeze for BasicCoverageBlockData
impl RefUnwindSafe for BasicCoverageBlockData
impl Send for BasicCoverageBlockData
impl Sync for BasicCoverageBlockData
impl Unpin for BasicCoverageBlockData
impl UnwindSafe for BasicCoverageBlockData
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
source§impl<T> CloneToUninit for Twhere
    T: Clone,
 
impl<T> CloneToUninit for Twhere
    T: Clone,
source§default unsafe fn clone_to_uninit(&self, dst: *mut T)
 
default unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit)source§impl<T, R> CollectAndApply<T, R> for T
 
impl<T, R> CollectAndApply<T, R> for T
source§impl<T> Filterable for T
 
impl<T> Filterable for T
source§fn filterable(
    self,
    filter_name: &'static str,
) -> RequestFilterDataProvider<T, fn(_: DataRequest<'_>) -> bool>
 
fn filterable( self, filter_name: &'static str, ) -> RequestFilterDataProvider<T, fn(_: DataRequest<'_>) -> bool>
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<T> IntoEither for T
 
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
 
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
 
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moresource§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
source§impl<T> Pointable for T
 
impl<T> Pointable for T
source§impl<I, T, U> Upcast<I, U> for Twhere
    U: UpcastFrom<I, T>,
 
impl<I, T, U> Upcast<I, U> for Twhere
    U: UpcastFrom<I, T>,
source§impl<I, T> UpcastFrom<I, T> for T
 
impl<I, T> UpcastFrom<I, T> for T
fn upcast_from(from: T, _tcx: I) -> 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: 24 bytes