diff options
author | Brad King <brad.king@kitware.com> | 2009-03-02 20:33:18 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2009-03-02 20:33:18 (GMT) |
commit | 91a8569648aba920a4b168eb25e946ca012a93ba (patch) | |
tree | 722c768d8d402479d1c44ee205cd3a63f2d0faad /Source/CTest/cmCTestCoverageHandler.cxx | |
parent | 3078fef81c9f6d00aceba5ca16435ba37f1cdf03 (diff) | |
download | CMake-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.cxx | 45 |
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(); +} |