struct Instrumentor<'a, 'tcx> {
    tcx: TyCtxt<'tcx>,
    mir_body: &'a mut Body<'tcx>,
    source_file: Lrc<SourceFile>,
    fn_sig_span: Span,
    body_span: Span,
    function_source_hash: u64,
    basic_coverage_blocks: CoverageGraph,
    coverage_counters: CoverageCounters,
}

Fields§

§tcx: TyCtxt<'tcx>§mir_body: &'a mut Body<'tcx>§source_file: Lrc<SourceFile>§fn_sig_span: Span§body_span: Span§function_source_hash: u64§basic_coverage_blocks: CoverageGraph§coverage_counters: CoverageCounters

Implementations§

source§

impl<'a, 'tcx> Instrumentor<'a, 'tcx>

source

fn new(tcx: TyCtxt<'tcx>, mir_body: &'a mut Body<'tcx>) -> Self

source

fn inject_counters(&'a mut self)

source

fn inject_coverage_span_counters(&mut self, coverage_spans: &CoverageSpans)

Injects a single StatementKind::Coverage for each BCB that has one or more coverage spans.

source

fn inject_indirect_counters(&mut self)

At this point, any BCB with coverage counters has already had its counter injected into MIR, and had its counter removed from coverage_counters (via take_counter()).

Any other counter associated with a BasicCoverageBlock, or its incoming edge, but not associated with a coverage span, should only exist if the counter is an Expression dependency (one of the expression operands). Collect them, and inject the additional counters into the MIR, without a reportable coverage span.

source

fn bcb_leader_bb(&self, bcb: BasicCoverageBlock) -> BasicBlock

source

fn bcb_last_bb(&self, bcb: BasicCoverageBlock) -> BasicBlock

source

fn bcb_data(&self, bcb: BasicCoverageBlock) -> &BasicCoverageBlockData

source

fn make_mir_coverage_kind(&self, counter_kind: &BcbCounter) -> CoverageKind

Auto Trait Implementations§

§

impl<'a, 'tcx> !RefUnwindSafe for Instrumentor<'a, 'tcx>

§

impl<'a, 'tcx> !Send for Instrumentor<'a, 'tcx>

§

impl<'a, 'tcx> !Sync for Instrumentor<'a, 'tcx>

§

impl<'a, 'tcx> Unpin for Instrumentor<'a, 'tcx>

§

impl<'a, 'tcx> !UnwindSafe for Instrumentor<'a, 'tcx>

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

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

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.

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: 344 bytes