Suppressions: Better XML formatting
This commit is contained in:
parent
a2b8eb7405
commit
87557afc43
|
@ -77,28 +77,32 @@ std::string Suppressions::parseXmlFile(const char *filename)
|
||||||
tinyxml2::XMLError error = doc.LoadFile(filename);
|
tinyxml2::XMLError error = doc.LoadFile(filename);
|
||||||
if (error == tinyxml2::XML_ERROR_FILE_NOT_FOUND)
|
if (error == tinyxml2::XML_ERROR_FILE_NOT_FOUND)
|
||||||
return "File not found";
|
return "File not found";
|
||||||
|
if (error != tinyxml2::XML_SUCCESS)
|
||||||
|
return "Failed to parse XML file";
|
||||||
|
|
||||||
const tinyxml2::XMLElement * const rootnode = doc.FirstChildElement();
|
const tinyxml2::XMLElement * const rootnode = doc.FirstChildElement();
|
||||||
for (const tinyxml2::XMLElement * e = rootnode->FirstChildElement(); e; e = e->NextSiblingElement()) {
|
for (const tinyxml2::XMLElement * e = rootnode->FirstChildElement(); e; e = e->NextSiblingElement()) {
|
||||||
if (std::strcmp(e->Name(), "suppress") == 0) {
|
if (std::strcmp(e->Name(), "suppress") != 0)
|
||||||
Suppression s;
|
return "Invalid suppression xml file format, expected <suppress> element but got a <" + std::string(e->Name()) + '>';
|
||||||
for (const tinyxml2::XMLElement * e2 = e->FirstChildElement(); e2; e2 = e2->NextSiblingElement()) {
|
|
||||||
const char *text = e2->GetText() ? e2->GetText() : "";
|
Suppression s;
|
||||||
if (std::strcmp(e2->Name(), "id") == 0)
|
for (const tinyxml2::XMLElement * e2 = e->FirstChildElement(); e2; e2 = e2->NextSiblingElement()) {
|
||||||
s.errorId = text;
|
const char *text = e2->GetText() ? e2->GetText() : "";
|
||||||
else if (std::strcmp(e2->Name(), "fileName") == 0)
|
if (std::strcmp(e2->Name(), "id") == 0)
|
||||||
s.fileName = text;
|
s.errorId = text;
|
||||||
else if (std::strcmp(e2->Name(), "lineNumber") == 0)
|
else if (std::strcmp(e2->Name(), "fileName") == 0)
|
||||||
s.lineNumber = std::atoi(text);
|
s.fileName = text;
|
||||||
else if (std::strcmp(e2->Name(), "symbolName") == 0)
|
else if (std::strcmp(e2->Name(), "lineNumber") == 0)
|
||||||
s.symbolName = text;
|
s.lineNumber = std::atoi(text);
|
||||||
else
|
else if (std::strcmp(e2->Name(), "symbolName") == 0)
|
||||||
return std::string("Unknown suppression element '") + e2->Name() + "'";
|
s.symbolName = text;
|
||||||
}
|
else
|
||||||
const std::string err = addSuppression(s);
|
return "Unknown suppression element <" + std::string(e2->Name()) + ">, expected <id>/<fileName>/<lineNumber>/<symbolName>";
|
||||||
if (!err.empty())
|
|
||||||
return err;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const std::string err = addSuppression(s);
|
||||||
|
if (!err.empty())
|
||||||
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
return "";
|
return "";
|
||||||
|
|
Loading…
Reference in New Issue