summaryrefslogtreecommitdiffstats
path: root/Source/CTest/cmCTestCoverageHandler.cxx
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2009-03-02 20:33:18 (GMT)
committerBrad King <brad.king@kitware.com>2009-03-02 20:33:18 (GMT)
commit91a8569648aba920a4b168eb25e946ca012a93ba (patch)
tree722c768d8d402479d1c44ee205cd3a63f2d0faad /Source/CTest/cmCTestCoverageHandler.cxx
parent3078fef81c9f6d00aceba5ca16435ba37f1cdf03 (diff)
downloadCMake-91a8569648aba920a4b168eb25e946ca012a93ba.zip
CMake-91a8569648aba920a4b168eb25e946ca012a93ba.tar.gz
CMake-91a8569648aba920a4b168eb25e946ca012a93ba.tar.bz2
ENH: Teach ctest_coverage to filter with LABELS
This teaches ctest_coverage() to report only coverage of files labeled with at least one label given by a new LABELS option.
Diffstat (limited to 'Source/CTest/cmCTestCoverageHandler.cxx')
-rw-r--r--Source/CTest/cmCTestCoverageHandler.cxx45
1 files changed, 45 insertions, 0 deletions
diff --git a/Source/CTest/cmCTestCoverageHandler.cxx b/Source/CTest/cmCTestCoverageHandler.cxx
index f39b7e1..1faf05a 100644
--- a/Source/CTest/cmCTestCoverageHandler.cxx
+++ b/Source/CTest/cmCTestCoverageHandler.cxx
@@ -17,6 +17,7 @@
#include "cmCTestCoverageHandler.h"
#include "cmCTest.h"
#include "cmake.h"
+#include "cmMakefile.h"
#include "cmSystemTools.h"
#include "cmGeneratedFileStream.h"
#include "cmXMLSafe.h"
@@ -24,6 +25,8 @@
#include <cmsys/Process.h>
#include <cmsys/RegularExpression.hxx>
#include <cmsys/Glob.hxx>
+#include <cmsys/stl/iterator>
+#include <cmsys/stl/algorithm>
#include <stdlib.h>
#include <math.h>
@@ -156,6 +159,7 @@ void cmCTestCoverageHandler::Initialize()
this->SourceLabels.clear();
this->LabelIdMap.clear();
this->Labels.clear();
+ this->LabelFilter.clear();
}
//----------------------------------------------------------------------
@@ -207,6 +211,11 @@ bool cmCTestCoverageHandler::ShouldIDoCoverage(const char* file,
const char* srcDir,
const char* binDir)
{
+ if(this->IsFilteredOut(file))
+ {
+ return false;
+ }
+
std::vector<cmsys::RegularExpression>::iterator sit;
for ( sit = this->CustomCoverageExcludeRegex.begin();
sit != this->CustomCoverageExcludeRegex.end(); ++ sit )
@@ -1817,3 +1826,39 @@ void cmCTestCoverageHandler::WriteXMLLabels(std::ofstream& os,
os << "\t\t</Labels>\n";
}
}
+
+//----------------------------------------------------------------------------
+void
+cmCTestCoverageHandler::SetLabelFilter(std::set<cmStdString> const& labels)
+{
+ this->LabelFilter.clear();
+ for(std::set<cmStdString>::const_iterator li = labels.begin();
+ li != labels.end(); ++li)
+ {
+ this->LabelFilter.insert(this->GetLabelId(*li));
+ }
+}
+
+//----------------------------------------------------------------------
+bool cmCTestCoverageHandler::IsFilteredOut(std::string const& source)
+{
+ // If there is no label filter then nothing is filtered out.
+ if(this->LabelFilter.empty())
+ {
+ return false;
+ }
+
+ // The source is filtered out if it does not have any labels in
+ // common with the filter set.
+ std::vector<int> ids;
+ std::string shortSrc = this->CTest->GetShortPathToFile(source.c_str());
+ LabelMapType::const_iterator li = this->SourceLabels.find(shortSrc);
+ if(li != this->SourceLabels.end() && !li->second.empty())
+ {
+ cmsys_stl::set_intersection
+ (li->second.begin(), li->second.end(),
+ this->LabelFilter.begin(), this->LabelFilter.end(),
+ cmsys_stl::back_inserter(ids));
+ }
+ return ids.empty();
+}