mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-25 00:24:26 +00:00
llvm-cov: Disentangle the coverage data logic from the display (NFC)
This splits the logic for actually looking up coverage information from the logic that displays it. These were tangled rather thoroughly so this change is a bit large, but it mostly consists of moving things around. The coverage lookup logic itself now lives in the library, rather than being spread between the library and the tool. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@218184 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -17,21 +17,22 @@
|
||||
|
||||
using namespace llvm;
|
||||
|
||||
bool NameCoverageFilter::matches(const FunctionCoverageMapping &Function) {
|
||||
bool NameCoverageFilter::matches(const coverage::FunctionRecord &Function) {
|
||||
StringRef FuncName = Function.Name;
|
||||
return FuncName.find(Name) != StringRef::npos;
|
||||
}
|
||||
|
||||
bool NameRegexCoverageFilter::matches(const FunctionCoverageMapping &Function) {
|
||||
bool
|
||||
NameRegexCoverageFilter::matches(const coverage::FunctionRecord &Function) {
|
||||
return llvm::Regex(Regex).match(Function.Name);
|
||||
}
|
||||
|
||||
bool RegionCoverageFilter::matches(const FunctionCoverageMapping &Function) {
|
||||
bool RegionCoverageFilter::matches(const coverage::FunctionRecord &Function) {
|
||||
return PassesThreshold(FunctionCoverageSummary::get(Function)
|
||||
.RegionCoverage.getPercentCovered());
|
||||
}
|
||||
|
||||
bool LineCoverageFilter::matches(const FunctionCoverageMapping &Function) {
|
||||
bool LineCoverageFilter::matches(const coverage::FunctionRecord &Function) {
|
||||
return PassesThreshold(
|
||||
FunctionCoverageSummary::get(Function).LineCoverage.getPercentCovered());
|
||||
}
|
||||
@ -40,7 +41,7 @@ void CoverageFilters::push_back(std::unique_ptr<CoverageFilter> Filter) {
|
||||
Filters.push_back(std::move(Filter));
|
||||
}
|
||||
|
||||
bool CoverageFilters::matches(const FunctionCoverageMapping &Function) {
|
||||
bool CoverageFilters::matches(const coverage::FunctionRecord &Function) {
|
||||
for (const auto &Filter : Filters) {
|
||||
if (Filter->matches(Function))
|
||||
return true;
|
||||
@ -48,7 +49,8 @@ bool CoverageFilters::matches(const FunctionCoverageMapping &Function) {
|
||||
return false;
|
||||
}
|
||||
|
||||
bool CoverageFiltersMatchAll::matches(const FunctionCoverageMapping &Function) {
|
||||
bool
|
||||
CoverageFiltersMatchAll::matches(const coverage::FunctionRecord &Function) {
|
||||
for (const auto &Filter : Filters) {
|
||||
if (!Filter->matches(Function))
|
||||
return false;
|
||||
|
Reference in New Issue
Block a user