move setting flags checks out of for loops, make them const.

This commit is contained in:
Matthias Krüger 2015-04-07 07:07:08 +02:00
parent 3b84706088
commit eedcb6abcb
11 changed files with 38 additions and 20 deletions

View File

@ -118,8 +118,8 @@ static bool variableIsUsedInScope(const Token* start, unsigned int varId, const
void CheckAutoVariables::assignFunctionArg() void CheckAutoVariables::assignFunctionArg()
{ {
bool style = _settings->isEnabled("style"); const bool style = _settings->isEnabled("style");
bool warning = _settings->isEnabled("warning"); const bool warning = _settings->isEnabled("warning");
if (!style && !warning) if (!style && !warning)
return; return;

View File

@ -979,6 +979,8 @@ static const Scope* findFunctionOf(const Scope* scope)
void CheckClass::checkMemset() void CheckClass::checkMemset()
{ {
const bool printWarnings = _settings->isEnabled("warning");
const std::size_t functions = symbolDatabase->functionScopes.size(); const std::size_t functions = symbolDatabase->functionScopes.size();
for (std::size_t i = 0; i < functions; ++i) { for (std::size_t i = 0; i < functions; ++i) {
const Scope * scope = symbolDatabase->functionScopes[i]; const Scope * scope = symbolDatabase->functionScopes[i];
@ -1052,7 +1054,7 @@ void CheckClass::checkMemset()
std::list<const Scope *> parsedTypes; std::list<const Scope *> parsedTypes;
checkMemsetType(scope, tok->tokAt(2), tok->variable()->typeScope(), true, parsedTypes); checkMemsetType(scope, tok->tokAt(2), tok->variable()->typeScope(), true, parsedTypes);
if (tok->variable()->typeScope()->numConstructors > 0 && _settings->isEnabled("warning")) if (tok->variable()->typeScope()->numConstructors > 0 && printWarnings)
mallocOnClassWarning(tok, tok->strAt(2), tok->variable()->typeScope()->classDef); mallocOnClassWarning(tok, tok->strAt(2), tok->variable()->typeScope()->classDef);
} }
} }
@ -1061,6 +1063,8 @@ void CheckClass::checkMemset()
void CheckClass::checkMemsetType(const Scope *start, const Token *tok, const Scope *type, bool allocation, std::list<const Scope *> parsedTypes) void CheckClass::checkMemsetType(const Scope *start, const Token *tok, const Scope *type, bool allocation, std::list<const Scope *> parsedTypes)
{ {
const bool printPortability = _settings->isEnabled("portability");
// If type has been checked there is no need to check it again // If type has been checked there is no need to check it again
if (std::find(parsedTypes.begin(), parsedTypes.end(), type) != parsedTypes.end()) if (std::find(parsedTypes.begin(), parsedTypes.end(), type) != parsedTypes.end())
return; return;
@ -1110,7 +1114,7 @@ void CheckClass::checkMemsetType(const Scope *start, const Token *tok, const Sco
checkMemsetType(start, tok, typeScope, allocation, parsedTypes); checkMemsetType(start, tok, typeScope, allocation, parsedTypes);
// check for float // check for float
else if (tok->str() == "memset" && var->isFloatingType() && _settings->isEnabled("portability")) else if (tok->str() == "memset" && var->isFloatingType() && printPortability)
memsetErrorFloat(tok, type->classDef->str()); memsetErrorFloat(tok, type->classDef->str());
} }
} }

View File

@ -584,8 +584,8 @@ template<class T> static T getvalue(const int test, const T value1, const T valu
void CheckCondition::checkIncorrectLogicOperator() void CheckCondition::checkIncorrectLogicOperator()
{ {
bool style = _settings->isEnabled("style"); const bool style = _settings->isEnabled("style");
bool warning = _settings->isEnabled("warning"); const bool warning = _settings->isEnabled("warning");
if (!style && !warning) if (!style && !warning)
return; return;

View File

@ -100,6 +100,8 @@ void CheckIO::checkFileUsage()
}; };
static const std::set<std::string> whitelist(_whitelist, _whitelist + sizeof(_whitelist)/sizeof(*_whitelist)); static const std::set<std::string> whitelist(_whitelist, _whitelist + sizeof(_whitelist)/sizeof(*_whitelist));
const bool windows = _settings->isWindowsPlatform(); const bool windows = _settings->isWindowsPlatform();
const bool printPortability = _settings->isEnabled("portability");
const bool printWarnings = _settings->isEnabled("warning");
std::map<unsigned int, Filepointer> filepointers; std::map<unsigned int, Filepointer> filepointers;
@ -179,7 +181,7 @@ void CheckIO::checkFileUsage()
operation = Filepointer::OPEN; operation = Filepointer::OPEN;
} else if ((tok->str() == "rewind" || tok->str() == "fseek" || tok->str() == "fsetpos" || tok->str() == "fflush") || } else if ((tok->str() == "rewind" || tok->str() == "fseek" || tok->str() == "fsetpos" || tok->str() == "fflush") ||
(windows && tok->str() == "_fseeki64")) { (windows && tok->str() == "_fseeki64")) {
if (_settings->isEnabled("portability") && tok->str() == "fflush") { if (printPortability && tok->str() == "fflush") {
fileTok = tok->tokAt(2); fileTok = tok->tokAt(2);
if (fileTok) { if (fileTok) {
if (fileTok->str() == "stdin") if (fileTok->str() == "stdin")
@ -270,7 +272,7 @@ void CheckIO::checkFileUsage()
case Filepointer::POSITIONING: case Filepointer::POSITIONING:
if (f.mode == CLOSED) if (f.mode == CLOSED)
useClosedFileError(tok); useClosedFileError(tok);
else if (f.append_mode == Filepointer::APPEND && tok->str() != "fflush" && _settings->isEnabled("warning")) else if (f.append_mode == Filepointer::APPEND && tok->str() != "fflush" && printWarnings)
seekOnAppendedFileError(tok); seekOnAppendedFileError(tok);
break; break;
case Filepointer::READ: case Filepointer::READ:

View File

@ -308,6 +308,8 @@ void CheckNullPointer::nullPointerLinkedList()
void CheckNullPointer::nullPointerByDeRefAndChec() void CheckNullPointer::nullPointerByDeRefAndChec()
{ {
const bool printWarnings = _settings->isEnabled("warning");
for (const Token *tok = _tokenizer->tokens(); tok; tok = tok->next()) { for (const Token *tok = _tokenizer->tokens(); tok; tok = tok->next()) {
const Variable *var = tok->variable(); const Variable *var = tok->variable();
if (!var || !var->isPointer() || tok == var->nameToken()) if (!var || !var->isPointer() || tok == var->nameToken())
@ -336,7 +338,7 @@ void CheckNullPointer::nullPointerByDeRefAndChec()
if (std::find(varlist.begin(), varlist.end(), tok) != varlist.end()) { if (std::find(varlist.begin(), varlist.end(), tok) != varlist.end()) {
if (value->condition == nullptr) if (value->condition == nullptr)
nullPointerError(tok, tok->str(), false, value->defaultArg); nullPointerError(tok, tok->str(), false, value->defaultArg);
else if (_settings->isEnabled("warning")) else if (printWarnings)
nullPointerError(tok, tok->str(), value->condition, value->inconclusive); nullPointerError(tok, tok->str(), value->condition, value->inconclusive);
} }
continue; continue;
@ -356,7 +358,7 @@ void CheckNullPointer::nullPointerByDeRefAndChec()
if (value->condition == nullptr) if (value->condition == nullptr)
nullPointerError(tok, tok->str(), value->inconclusive, value->defaultArg); nullPointerError(tok, tok->str(), value->inconclusive, value->defaultArg);
else if (_settings->isEnabled("warning")) else if (printWarnings)
nullPointerError(tok, tok->str(), value->condition, value->inconclusive); nullPointerError(tok, tok->str(), value->condition, value->inconclusive);
} }
} }

View File

@ -1785,6 +1785,8 @@ void CheckOther::constStatementError(const Token *tok, const std::string &type)
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void CheckOther::checkZeroDivision() void CheckOther::checkZeroDivision()
{ {
const bool printWarnings = _settings->isEnabled("warning");
for (const Token *tok = _tokenizer->tokens(); tok; tok = tok->next()) { for (const Token *tok = _tokenizer->tokens(); tok; tok = tok->next()) {
if (Token::Match(tok, "div|ldiv|lldiv|imaxdiv ( %num% , %num% )") && if (Token::Match(tok, "div|ldiv|lldiv|imaxdiv ( %num% , %num% )") &&
MathLib::isInt(tok->strAt(4)) && MathLib::isInt(tok->strAt(4)) &&
@ -1804,7 +1806,7 @@ void CheckOther::checkZeroDivision()
continue; continue;
if (value->condition == nullptr) if (value->condition == nullptr)
zerodivError(tok, value->inconclusive); zerodivError(tok, value->inconclusive);
else if (_settings->isEnabled("warning")) else if (printWarnings)
zerodivcondError(value->condition,tok,value->inconclusive); zerodivcondError(value->condition,tok,value->inconclusive);
} }
} }
@ -1872,7 +1874,7 @@ void CheckOther::nanInArithmeticExpressionError(const Token *tok)
void CheckOther::checkMathFunctions() void CheckOther::checkMathFunctions()
{ {
bool styleC99 = _settings->isEnabled("style") && _settings->standards.c != Standards::C89 && _settings->standards.cpp != Standards::CPP03; bool styleC99 = _settings->isEnabled("style") && _settings->standards.c != Standards::C89 && _settings->standards.cpp != Standards::CPP03;
bool printWarnings = _settings->isEnabled("warning"); const bool printWarnings = _settings->isEnabled("warning");
const SymbolDatabase *symbolDatabase = _tokenizer->getSymbolDatabase(); const SymbolDatabase *symbolDatabase = _tokenizer->getSymbolDatabase();
const std::size_t functions = symbolDatabase->functionScopes.size(); const std::size_t functions = symbolDatabase->functionScopes.size();
@ -2553,8 +2555,8 @@ void CheckOther::checkIncompleteArrayFill()
{ {
if (!_settings->inconclusive) if (!_settings->inconclusive)
return; return;
bool warning = _settings->isEnabled("warning"); const bool warning = _settings->isEnabled("warning");
bool portability = _settings->isEnabled("portability"); const bool portability = _settings->isEnabled("portability");
if (!portability && !warning) if (!portability && !warning)
return; return;

View File

@ -1238,6 +1238,7 @@ void CheckStl::checkAutoPointer()
std::map<unsigned int, const std::string> mallocVarId; // variables allocated by the malloc-like function std::map<unsigned int, const std::string> mallocVarId; // variables allocated by the malloc-like function
static const char STL_CONTAINER_LIST[] = "array|bitset|deque|list|forward_list|map|multimap|multiset|priority_queue|queue|set|stack|vector|hash_map|hash_multimap|hash_set|unordered_map|unordered_multimap|unordered_set|unordered_multiset|basic_string"; static const char STL_CONTAINER_LIST[] = "array|bitset|deque|list|forward_list|map|multimap|multiset|priority_queue|queue|set|stack|vector|hash_map|hash_multimap|hash_set|unordered_map|unordered_multimap|unordered_set|unordered_multiset|basic_string";
const int malloc = _settings->library.alloc("malloc"); // allocation function, which are not compatible with auto_ptr const int malloc = _settings->library.alloc("malloc"); // allocation function, which are not compatible with auto_ptr
const bool printStyle = _settings->isEnabled("style");
for (const Token *tok = _tokenizer->tokens(); tok; tok = tok->next()) { for (const Token *tok = _tokenizer->tokens(); tok; tok = tok->next()) {
if (Token::simpleMatch(tok, "auto_ptr <")) { if (Token::simpleMatch(tok, "auto_ptr <")) {
@ -1284,7 +1285,7 @@ void CheckStl::checkAutoPointer()
} }
} else { } else {
if (Token::Match(tok, "%name% = %var% ;")) { if (Token::Match(tok, "%name% = %var% ;")) {
if (_settings->isEnabled("style")) { if (printStyle) {
std::set<unsigned int>::const_iterator iter = autoPtrVarId.find(tok->tokAt(2)->varId()); std::set<unsigned int>::const_iterator iter = autoPtrVarId.find(tok->tokAt(2)->varId());
if (iter != autoPtrVarId.end()) { if (iter != autoPtrVarId.end()) {
autoPointerError(tok->tokAt(2)); autoPointerError(tok->tokAt(2));

View File

@ -99,6 +99,8 @@ static bool astGetSizeSign(const Settings *settings, const Token *tok, unsigned
void CheckType::checkTooBigBitwiseShift() void CheckType::checkTooBigBitwiseShift()
{ {
const bool printWarnings = _settings->isEnabled("warning");
// unknown sizeof(int) => can't run this checker // unknown sizeof(int) => can't run this checker
if (_settings->platformType == Settings::Unspecified) if (_settings->platformType == Settings::Unspecified)
return; return;
@ -134,7 +136,7 @@ void CheckType::checkTooBigBitwiseShift()
const ValueFlow::Value *value = tok->astOperand2()->getValueGE(lhsbits, _settings); const ValueFlow::Value *value = tok->astOperand2()->getValueGE(lhsbits, _settings);
if (!value) if (!value)
continue; continue;
if (value->condition && !_settings->isEnabled("warning")) if (value->condition && !printWarnings)
continue; continue;
if (value->inconclusive && !_settings->inconclusive) if (value->inconclusive && !_settings->inconclusive)
continue; continue;

View File

@ -35,6 +35,8 @@ void CheckVaarg::va_start_argument()
{ {
const SymbolDatabase* const symbolDatabase = _tokenizer->getSymbolDatabase(); const SymbolDatabase* const symbolDatabase = _tokenizer->getSymbolDatabase();
const std::size_t functions = symbolDatabase->functionScopes.size(); const std::size_t functions = symbolDatabase->functionScopes.size();
const bool printWarnings = _settings->isEnabled("warning");
for (std::size_t i = 0; i < functions; ++i) { for (std::size_t i = 0; i < functions; ++i) {
const Scope* scope = symbolDatabase->functionScopes[i]; const Scope* scope = symbolDatabase->functionScopes[i];
const Function* function = scope->function; const Function* function = scope->function;
@ -48,7 +50,7 @@ void CheckVaarg::va_start_argument()
const Variable* var = param2->variable(); const Variable* var = param2->variable();
if (var && var->isReference()) if (var && var->isReference())
referenceAs_va_start_error(param2, var->name()); referenceAs_va_start_error(param2, var->name());
if (var && var->index() + 2 < function->argCount() && _settings->isEnabled("warning")) { if (var && var->index() + 2 < function->argCount() && printWarnings) {
std::list<Variable>::const_reverse_iterator it = function->argumentList.rbegin(); std::list<Variable>::const_reverse_iterator it = function->argumentList.rbegin();
++it; ++it;
wrongParameterTo_va_start_error(tok, var->name(), it->name()); wrongParameterTo_va_start_error(tok, var->name(), it->name());

View File

@ -2870,6 +2870,8 @@ static bool getlines(std::istream &istr, std::string &line)
bool Preprocessor::validateCfg(const std::string &code, const std::string &cfg) bool Preprocessor::validateCfg(const std::string &code, const std::string &cfg)
{ {
const bool printInformation = (_settings && _settings->isEnabled("information"));
// fill up "macros" with empty configuration macros // fill up "macros" with empty configuration macros
std::set<std::string> macros; std::set<std::string> macros;
for (std::string::size_type pos = 0; pos < cfg.size();) { for (std::string::size_type pos = 0; pos < cfg.size();) {
@ -2917,7 +2919,7 @@ bool Preprocessor::validateCfg(const std::string &code, const std::string &cfg)
if (pos2 < code.size() && (std::isalnum((unsigned char)code[pos2]) || code[pos2] == '_')) if (pos2 < code.size() && (std::isalnum((unsigned char)code[pos2]) || code[pos2] == '_'))
continue; continue;
// macro is used in code, return false // macro is used in code, return false
if (_settings && _settings->isEnabled("information")) if (printInformation)
validateCfgError(cfg, macro); validateCfgError(cfg, macro);
return false; return false;
} }

View File

@ -7515,6 +7515,7 @@ void Tokenizer::simplifyEnum()
std::string className; std::string className;
int classLevel = 0; int classLevel = 0;
bool goback = false; bool goback = false;
const bool printStyle = _settings->isEnabled("style");
for (Token *tok = list.front(); tok; tok = tok->next()) { for (Token *tok = list.front(); tok; tok = tok->next()) {
if (goback) { if (goback) {
@ -7776,7 +7777,7 @@ void Tokenizer::simplifyEnum()
if (prev->str() == "(" && (!Token::Match(prev->tokAt(-2), "%type%|::|*|& %type% (") || prev->strAt(-2) == "else")) if (prev->str() == "(" && (!Token::Match(prev->tokAt(-2), "%type%|::|*|& %type% (") || prev->strAt(-2) == "else"))
continue; continue;
shadowVars.insert(arg->str()); shadowVars.insert(arg->str());
if (inScope && _settings->isEnabled("style")) { if (inScope && printStyle) {
const EnumValue& enumValue = enumValues.find(arg->str())->second; const EnumValue& enumValue = enumValues.find(arg->str())->second;
duplicateEnumError(arg, enumValue.name, "Function argument"); duplicateEnumError(arg, enumValue.name, "Function argument");
} }
@ -7796,7 +7797,7 @@ void Tokenizer::simplifyEnum()
(Token::Match(prev->previous(), "%type% *|&") && (prev->previous()->isStandardType() || prev->strAt(-1) == "const" || Token::Match(prev->tokAt(-2), ";|{|}")))) { (Token::Match(prev->previous(), "%type% *|&") && (prev->previous()->isStandardType() || prev->strAt(-1) == "const" || Token::Match(prev->tokAt(-2), ";|{|}")))) {
// variable declaration? // variable declaration?
shadowVars.insert(tok3->str()); shadowVars.insert(tok3->str());
if (inScope && _settings->isEnabled("style")) { if (inScope && printStyle) {
const EnumValue& enumValue = enumValues.find(tok3->str())->second; const EnumValue& enumValue = enumValues.find(tok3->str())->second;
duplicateEnumError(tok3, enumValue.name, "Variable"); duplicateEnumError(tok3, enumValue.name, "Variable");
} }