/* * Cppcheck - A tool for static C/C++ code analysis * Copyright (C) 2007-2009 Daniel Marjamäki, Reijo Tomperi, Nicolas Le Cam, * Leandro Penz, Kimmo Varis, Vesa Pikki * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see ErrorLogger::ErrorMessage::ErrorMessage() { } #include ErrorLogger::ErrorMessage::ErrorMessage(const std::list &callStack, const std::string &severity, const std::string &msg, const std::string &id) { _callStack = callStack; _severity = severity; _msg = msg; _id = id; } std::string ErrorLogger::ErrorMessage::serialize() const { std::ostringstream oss; oss << _id.length() << " " << _id; oss << _severity.length() << " " << _severity; oss << _msg.length() << " " << _msg; oss << _callStack.size() << " "; for (std::list::const_iterator tok = _callStack.begin(); tok != _callStack.end(); ++tok) { std::ostringstream smallStream; smallStream << (*tok).line << ":" << (*tok).file; oss << smallStream.str().length() << " " << smallStream.str(); } return oss.str(); } bool ErrorLogger::ErrorMessage::deserialize(const std::string &data) { _callStack.clear(); std::istringstream iss(data); std::vector results; while (iss.good()) { unsigned int len = 0; if (!(iss >> len)) return false; iss.get(); std::string temp; for (unsigned int i = 0; i < len && iss.good(); ++i) { char c = iss.get(); temp.append(1, c); } results.push_back(temp); if (results.size() == 3) break; } _id = results[0]; _severity = results[1]; _msg = results[2]; unsigned int stackSize = 0; if (!(iss >> stackSize)) return false; while (iss.good()) { unsigned int len = 0; if (!(iss >> len)) return false; iss.get(); std::string temp; for (unsigned int i = 0; i < len && iss.good(); ++i) { char c = iss.get(); temp.append(1, c); } ErrorLogger::ErrorMessage::FileLocation loc; loc.file = temp.substr(temp.find(':') + 1); temp = temp.substr(0, temp.find(':')); std::istringstream fiss(temp); fiss >> loc.line; _callStack.push_back(loc); if (_callStack.size() >= stackSize) break; } return true; } std::string ErrorLogger::ErrorMessage::toXML() const { std::ostringstream xml; xml << ""; return xml.str(); } std::string ErrorLogger::ErrorMessage::toText() const { std::ostringstream text; text << callStackToString(_callStack) << ": (" << _severity << ") " << _msg; return text.str(); } void ErrorLogger::_writemsg(const Tokenizer *tokenizer, const Token *tok, const char severity[], const std::string &msg, const std::string &id) { std::list callstack; callstack.push_back(tok); _writemsg(tokenizer, callstack, severity, msg, id); } void ErrorLogger::_writemsg(const Tokenizer *tokenizer, const std::list &callstack, const char severity[], const std::string &msg, const std::string &id) { std::list locationList; for (std::list::const_iterator tok = callstack.begin(); tok != callstack.end(); ++tok) { ErrorLogger::ErrorMessage::FileLocation loc; loc.file = tokenizer->file(*tok); loc.line = (*tok)->linenr(); locationList.push_back(loc); } reportErr(ErrorLogger::ErrorMessage(locationList, severity, msg, id)); } void ErrorLogger::_writemsg(const std::string &msg, const std::string &id) { std::ostringstream xml; xml << ""; std::list empty; empty.push_back(ErrorLogger::ErrorMessage::FileLocation()); reportErr(ErrorLogger::ErrorMessage(empty, "severity", msg, "id")); } std::string ErrorLogger::callStackToString(const std::list &callStack) { std::ostringstream ostr; for (std::list::const_iterator tok = callStack.begin(); tok != callStack.end(); ++tok) ostr << (tok == callStack.begin() ? "" : " -> ") << "[" << (*tok).file << ":" << (*tok).line << "]"; return ostr.str(); }