From 86f1718b1c2de7d7ad44d867ce24eed24daec98f Mon Sep 17 00:00:00 2001 From: Robert Reif Date: Tue, 17 Aug 2010 17:20:54 +0200 Subject: [PATCH] Symbol database: Fixed the error reporting so errors are shown in the gui. Ticket: #1895 --- lib/checkclass.cpp | 16 ++-------------- lib/checkclass.h | 2 +- 2 files changed, 3 insertions(+), 15 deletions(-) diff --git a/lib/checkclass.cpp b/lib/checkclass.cpp index d4f6ffa66..2231359e8 100644 --- a/lib/checkclass.cpp +++ b/lib/checkclass.cpp @@ -63,7 +63,7 @@ void CheckClass::createSymbolDatabase() if (Token::Match(tok, "class|struct|namespace %var% [{:]")) { SpaceInfo *new_info = new SpaceInfo; - new_info->tokenizer = _tokenizer; + new_info->check = this; new_info->isNamespace = tok->str() == "namespace"; new_info->className = tok->next()->str(); new_info->classDef = tok; @@ -578,22 +578,10 @@ void CheckClass::SpaceInfo::getVarList() // If the vartok was set in the if-blocks above, create a entry for this variable.. if (vartok && vartok->str() != "operator") { -#ifndef NDEBUG if (vartok->varId() == 0) { - std::list locationList; - ErrorLogger::ErrorMessage::FileLocation loc; - loc.line = vartok->linenr(); - loc.setfile(tokenizer->file(vartok)); - locationList.push_back(loc); - - const ErrorLogger::ErrorMessage errmsg(locationList, - Severity::error, - "Internal error. CheckClass::SpaceInfo::getVarList found variable with varid 0.", - "cppcheckError"); - Check::reportError(errmsg); + check->reportError(vartok, Severity::error, "cppcheckError", "Internal error. CheckClass::SpaceInfo::getVarList found variable \'" + vartok->str() + "\' with varid 0."); } -#endif varlist.push_back(Var(vartok, false, priv, isMutable, isStatic, isClass)); } diff --git a/lib/checkclass.h b/lib/checkclass.h index 9357c5e2e..b1e82e4f5 100644 --- a/lib/checkclass.h +++ b/lib/checkclass.h @@ -214,7 +214,7 @@ private: struct SpaceInfo { - const Tokenizer *tokenizer; + CheckClass *check; bool isNamespace; std::string className; const Token *classDef; // class/struct/namespace token