Suppressions: Better XML formatting

This commit is contained in:
Daniel Marjamäki 2018-04-10 16:32:47 +02:00
parent a2b8eb7405
commit 87557afc43
1 changed files with 22 additions and 18 deletions

View File

@ -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 "";