fixed false positives for the 'bitwise operator / comparison operator' check

This commit is contained in:
Daniel Marjamäki 2011-08-19 18:06:28 +02:00
parent eda9ff6fc5
commit 2dd1e290eb
3 changed files with 37 additions and 9 deletions

View File

@ -153,6 +153,10 @@ void CheckOther::clarifyCondition()
tok2 = tok2->link(); tok2 = tok2->link();
else if (Token::Match(tok2, "<|<=|==|!=|>|>=")) else if (Token::Match(tok2, "<|<=|==|!=|>|>="))
{ {
// This might be a template
if (!code_is_c() && Token::Match(tok2->previous(), "%var% <"))
break;
clarifyConditionError(tok, tok->strAt(2) == "=", false); clarifyConditionError(tok, tok->strAt(2) == "=", false);
break; break;
} }
@ -174,8 +178,13 @@ void CheckOther::clarifyCondition()
tok2 = tok2->link(); tok2 = tok2->link();
tok2 = tok2->next(); tok2 = tok2->next();
} }
if (Token::Match(tok2, "[&|^]")) if (Token::Match(tok2, "[&|^]"))
{ {
// don't write false positives when templates are used
if (Token::Match(tok, "<|>") && !code_is_c() && tok2->str() == "&")
continue;
clarifyConditionError(tok,false,true); clarifyConditionError(tok,false,true);
} }
} }
@ -3413,19 +3422,27 @@ static bool isFunction(const std::string &name, const Token *startToken)
return false; return false;
} }
void CheckOther::checkMisusedScopedObject() bool CheckOther::code_is_c() const
{
// Skip this check for .c files
{ {
const std::string fname = _tokenizer->getFiles()->at(0); const std::string fname = _tokenizer->getFiles()->at(0);
size_t position = fname.rfind("."); const size_t position = fname.rfind(".");
if (position != std::string::npos) if (position != std::string::npos)
{ {
const std::string ext = fname.substr(position); const std::string ext = fname.substr(position);
if (ext == ".c" || ext == ".C") if (ext == ".c" || ext == ".C")
return; return true;
} }
return false;
}
void CheckOther::checkMisusedScopedObject()
{
// Skip this check for .c files
if (code_is_c())
{
return;
} }
const SymbolDatabase * const symbolDatabase = _tokenizer->getSymbolDatabase(); const SymbolDatabase * const symbolDatabase = _tokenizer->getSymbolDatabase();

View File

@ -403,6 +403,8 @@ private:
return varname; return varname;
} }
bool code_is_c() const;
}; };
/// @} /// @}
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------

View File

@ -2642,6 +2642,12 @@ private:
" for (i = 0; i < 10; i++) {}\n" " for (i = 0; i < 10; i++) {}\n"
"}"); "}");
ASSERT_EQUALS("", errout.str()); ASSERT_EQUALS("", errout.str());
check("void f() {\n"
" if (x = a<int>()) {}\n"
"}");
ASSERT_EQUALS("", errout.str());
} }
// clarify conditions with bitwise operator and comparison // clarify conditions with bitwise operator and comparison
@ -2673,6 +2679,9 @@ private:
check("void f(std::list<int> &ints) { }"); check("void f(std::list<int> &ints) { }");
ASSERT_EQUALS("", errout.str()); ASSERT_EQUALS("", errout.str());
check("void f() { A<x &> a; }");
ASSERT_EQUALS("", errout.str());
} }
void incorrectStringCompare() void incorrectStringCompare()