blob: f2aec6db920cbf93541ed50e9edb39f37c3a7f86 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
|
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
file Copyright.txt or https://cmake.org/licensing for details. */
#ifndef cmParseJacocoCoverage_h
#define cmParseJacocoCoverage_h
#include "cmConfigure.h" // IWYU pragma: keep
#include <map>
#include <string>
#include <vector>
class cmCTest;
class cmCTestCoverageHandlerContainer;
/** \class cmParseJacocoCoverage
* \brief Parse JaCoCO coverage information
*
* This class is used to parse coverage information for
* java using the JaCoCo tool:
*
* http://www.eclemma.org/jacoco/trunk/index.html
*/
class cmParseJacocoCoverage
{
public:
cmParseJacocoCoverage(cmCTestCoverageHandlerContainer& cont, cmCTest* ctest);
bool LoadCoverageData(std::vector<std::string> const& files);
std::string PackageName;
std::string FileName;
std::string ModuleName;
std::string CurFileName;
private:
// implement virtual from parent
// remove files with no coverage
void RemoveUnCoveredFiles();
// Read a single mcov file
bool ReadJacocoXML(const char* f);
// split a string based on ,
bool SplitString(std::vector<std::string>& args, std::string const& line);
bool FindJavaFile(std::string const& routine, std::string& filepath);
void InitializeJavaFile(std::string& file);
bool LoadSource(std::string d);
class XMLParser;
std::map<std::string, std::string> RoutineToDirectory;
cmCTestCoverageHandlerContainer& Coverage;
cmCTest* CTest;
};
#endif
|