📄 errorlogger.cpp
字号:
/* * 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 <http://www.gnu.org/licenses/ */#include "errorlogger.h"#include "tokenize.h"#include "token.h"#include <sstream>ErrorLogger::ErrorMessage::ErrorMessage(){}#include <iostream>ErrorLogger::ErrorMessage::ErrorMessage(const std::list<FileLocation> &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<ErrorLogger::ErrorMessage::FileLocation>::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<std::string> 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 << "<error"; xml << " file=\"" << _callStack.back().file << "\""; xml << " line=\"" << _callStack.back().line << "\""; xml << " id=\"" << _id << "\""; xml << " severity=\"" << _severity << "\""; xml << " msg=\"" << _msg << "\""; 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<const Token *> callstack; callstack.push_back(tok); _writemsg(tokenizer, callstack, severity, msg, id);}void ErrorLogger::_writemsg(const Tokenizer *tokenizer, const std::list<const Token *> &callstack, const char severity[], const std::string &msg, const std::string &id){ std::list<ErrorLogger::ErrorMessage::FileLocation> locationList; for (std::list<const Token *>::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 << "<error"; xml << " id=\"" << id << "\""; xml << " msg=\"" << msg << "\""; xml << ">"; std::list<ErrorLogger::ErrorMessage::FileLocation> empty; empty.push_back(ErrorLogger::ErrorMessage::FileLocation()); reportErr(ErrorLogger::ErrorMessage(empty, "severity", msg, "id"));}std::string ErrorLogger::callStackToString(const std::list<ErrorLogger::ErrorMessage::FileLocation> &callStack){ std::ostringstream ostr; for (std::list<ErrorLogger::ErrorMessage::FileLocation>::const_iterator tok = callStack.begin(); tok != callStack.end(); ++tok) ostr << (tok == callStack.begin() ? "" : " -> ") << "[" << (*tok).file << ":" << (*tok).line << "]"; return ostr.str();}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -