Documentation ¶
Index ¶
- func SaturatingAdd(dst, src uint32) (uint32, bool)
- type Merger
- func (cm *Merger) Granularity() coverage.CounterGranularity
- func (m *Merger) MergeCounters(dst, src []uint32) (error, bool)
- func (cm *Merger) Mode() coverage.CounterMode
- func (cm *Merger) ResetModeAndGranularity()
- func (m *Merger) SaturatingAdd(dst, src uint32) uint32
- func (cm *Merger) SetModeAndGranularity(mdf string, cmode coverage.CounterMode, cgran coverage.CounterGranularity) error
- func (cm *Merger) SetModeMergePolicy(policy ModeMergePolicy)
- type ModeMergePolicy
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func SaturatingAdd ¶
Saturating add does a saturating addition of 'dst' and 'src', returning added value or math.MaxUint32 plus an overflow flag.
Types ¶
type Merger ¶
type Merger struct {
// contains filtered or unexported fields
}
Merger provides state and methods to help manage the process of merging together coverage counter data for a given function, for tools that need to implicitly merge counter as they read multiple coverage counter data files.
func (*Merger) Granularity ¶
func (cm *Merger) Granularity() coverage.CounterGranularity
func (*Merger) MergeCounters ¶
MergeCounters takes the counter values in 'src' and merges them into 'dst' according to the correct counter mode.
func (*Merger) Mode ¶
func (cm *Merger) Mode() coverage.CounterMode
func (*Merger) ResetModeAndGranularity ¶
func (cm *Merger) ResetModeAndGranularity()
func (*Merger) SaturatingAdd ¶
Saturating add does a saturating addition of 'dst' and 'src', returning added value or math.MaxUint32 if there is an overflow. Overflows are recorded in case the client needs to track them.
func (*Merger) SetModeAndGranularity ¶
func (cm *Merger) SetModeAndGranularity(mdf string, cmode coverage.CounterMode, cgran coverage.CounterGranularity) error
SetModeAndGranularity records the counter mode and granularity for the current merge. In the specific case of merging across coverage data files from different binaries, where we're combining data from more than one meta-data file, we need to check for and resolve mode/granularity clashes.
func (*Merger) SetModeMergePolicy ¶ added in go1.21.0
func (cm *Merger) SetModeMergePolicy(policy ModeMergePolicy)
type ModeMergePolicy ¶ added in go1.21.0
type ModeMergePolicy uint8
const ( ModeMergeStrict ModeMergePolicy = iota ModeMergeRelaxed )