Partial fix to #3452 (ErrorLogger: complain/raise assertion when error message has extra newlines etc)

http://sourceforge.net/apps/trac/cppcheck/ticket/3452
Add assert for newlines.
This commit is contained in:
Reijo Tomperi 2011-12-30 01:22:16 +02:00
parent ca0aade720
commit 65b58bcb99
2 changed files with 9 additions and 1 deletions

View File

@ -61,7 +61,7 @@ void CheckOther::incrementBooleanError(const Token *tok)
Severity::style, Severity::style,
"incrementboolean", "incrementboolean",
"The use of a variable of type bool with the ++ postfix operator is always true and deprecated by the C++ Standard.\n" "The use of a variable of type bool with the ++ postfix operator is always true and deprecated by the C++ Standard.\n"
"The operand of a postfix increment operator may be of type bool but it is deprecated by C++ Standard (Annex D-1) and the operand is always set to true\n" "The operand of a postfix increment operator may be of type bool but it is deprecated by C++ Standard (Annex D-1) and the operand is always set to true."
); );
} }

View File

@ -20,6 +20,7 @@
#include "path.h" #include "path.h"
#include "cppcheck.h" #include "cppcheck.h"
#include <cassert>
#include <sstream> #include <sstream>
#include <vector> #include <vector>
@ -48,6 +49,13 @@ ErrorLogger::ErrorMessage::ErrorMessage(const std::list<FileLocation> &callStack
void ErrorLogger::ErrorMessage::setmsg(const std::string &msg) void ErrorLogger::ErrorMessage::setmsg(const std::string &msg)
{ {
// If a message ends to a '\n' and contains only a one '\n'
// it will cause the _verboseMessage to be empty which will show
// as an empty message to the user if --verbose is used.
// Even this doesn't cause problems with messages that have multiple
// lines, none of the the error messages should end into it.
assert(!(msg[msg.size()-1]=='\n'));
// The summary and verbose message are separated by a newline // The summary and verbose message are separated by a newline
// If there is no newline then both the summary and verbose messages // If there is no newline then both the summary and verbose messages
// are the given message // are the given message