Struct rustc_codegen_llvm::llvm_::ffi::coverageinfo::CounterMappingRegion
source · #[repr(C)]pub struct CounterMappingRegion {
counter: Counter,
false_counter: Counter,
file_id: u32,
expanded_file_id: u32,
start_line: u32,
start_col: u32,
end_line: u32,
end_col: u32,
kind: RegionKind,
}
Expand description
This struct provides LLVM’s representation of a “CoverageMappingRegion”, encoded into the
coverage map, in accordance with the
LLVM Code Coverage Mapping Format.
The struct composes fields representing the Counter
type and value(s) (injected counter
ID, or expression type and operands), the source file (an indirect index into a “filenames
array”, encoded separately), and source location (start and end positions of the represented
code region).
Matches LLVMRustCounterMappingRegion.
Fields
counter: Counter
The counter type and type-dependent counter data, if any.
false_counter: Counter
If the RegionKind
is a BranchRegion
, this represents the counter
for the false branch of the region.
file_id: u32
An indirect reference to the source filename. In the LLVM Coverage Mapping Format, the
file_id is an index into a function-specific virtual_file_mapping
array of indexes
that, in turn, are used to look up the filename for this region.
expanded_file_id: u32
If the RegionKind
is an ExpansionRegion
, the expanded_file_id
can be used to find
the mapping regions created as a result of macro expansion, by checking if their file id
matches the expanded file id.
start_line: u32
1-based starting line of the mapping region.
start_col: u32
1-based starting column of the mapping region.
end_line: u32
1-based ending line of the mapping region.
end_col: u32
1-based ending column of the mapping region. If the high bit is set, the current mapping region is a gap area.
kind: RegionKind
Implementations
sourceimpl CounterMappingRegion
impl CounterMappingRegion
pub(crate) fn code_region(
counter: Counter,
file_id: u32,
start_line: u32,
start_col: u32,
end_line: u32,
end_col: u32
) -> Self
pub(crate) fn branch_region(
counter: Counter,
false_counter: Counter,
file_id: u32,
start_line: u32,
start_col: u32,
end_line: u32,
end_col: u32
) -> Self
pub(crate) fn expansion_region(
file_id: u32,
expanded_file_id: u32,
start_line: u32,
start_col: u32,
end_line: u32,
end_col: u32
) -> Self
pub(crate) fn skipped_region(
file_id: u32,
start_line: u32,
start_col: u32,
end_line: u32,
end_col: u32
) -> Self
pub(crate) fn gap_region(
counter: Counter,
file_id: u32,
start_line: u32,
start_col: u32,
end_line: u32,
end_col: u32
) -> Self
Trait Implementations
sourceimpl Clone for CounterMappingRegion
impl Clone for CounterMappingRegion
sourcefn clone(&self) -> CounterMappingRegion
fn clone(&self) -> CounterMappingRegion
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresourceimpl Debug for CounterMappingRegion
impl Debug for CounterMappingRegion
impl Copy for CounterMappingRegion
Auto Trait Implementations
impl RefUnwindSafe for CounterMappingRegion
impl Send for CounterMappingRegion
impl Sync for CounterMappingRegion
impl Unpin for CounterMappingRegion
impl UnwindSafe for CounterMappingRegion
Blanket Implementations
sourceimpl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut 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: 44 bytes