fixed false positives for the 'bitwise operator / comparison operator' check
This commit is contained in:
parent
eda9ff6fc5
commit
2dd1e290eb
|
@ -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();
|
||||||
|
|
|
@ -403,6 +403,8 @@ private:
|
||||||
|
|
||||||
return varname;
|
return varname;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool code_is_c() const;
|
||||||
};
|
};
|
||||||
/// @}
|
/// @}
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
|
@ -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()
|
||||||
|
|
Loading…
Reference in New Issue