Fixed #1740 (Undefined Behavior: Divide by zero)
This commit is contained in:
parent
08efad13b2
commit
2f62d180fe
|
@ -1870,8 +1870,7 @@ void CheckOther::checkZeroDivision()
|
||||||
{
|
{
|
||||||
for (const Token *tok = _tokenizer->tokens(); tok; tok = tok->next())
|
for (const Token *tok = _tokenizer->tokens(); tok; tok = tok->next())
|
||||||
{
|
{
|
||||||
|
if (Token::Match(tok, "[/%] %num%") &&
|
||||||
if (Token::Match(tok, "/ %num%") &&
|
|
||||||
MathLib::isInt(tok->next()->str()) &&
|
MathLib::isInt(tok->next()->str()) &&
|
||||||
MathLib::toLongNumber(tok->next()->str()) == 0L)
|
MathLib::toLongNumber(tok->next()->str()) == 0L)
|
||||||
{
|
{
|
||||||
|
|
|
@ -42,6 +42,7 @@ private:
|
||||||
TEST_CASE(zeroDiv3);
|
TEST_CASE(zeroDiv3);
|
||||||
TEST_CASE(zeroDiv4);
|
TEST_CASE(zeroDiv4);
|
||||||
TEST_CASE(zeroDiv5);
|
TEST_CASE(zeroDiv5);
|
||||||
|
TEST_CASE(zeroDiv6);
|
||||||
|
|
||||||
TEST_CASE(sprintf1); // Dangerous usage of sprintf
|
TEST_CASE(sprintf1); // Dangerous usage of sprintf
|
||||||
TEST_CASE(sprintf2);
|
TEST_CASE(sprintf2);
|
||||||
|
@ -367,6 +368,15 @@ private:
|
||||||
ASSERT_EQUALS("[test.cpp:3]: (error) Division by zero\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3]: (error) Division by zero\n", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void zeroDiv6()
|
||||||
|
{
|
||||||
|
check("void f()\n"
|
||||||
|
"{ { {\n"
|
||||||
|
" int a = b % 0;\n"
|
||||||
|
"} } }\n");
|
||||||
|
ASSERT_EQUALS("[test.cpp:3]: (error) Division by zero\n", errout.str());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void sprintfUsage(const char code[])
|
void sprintfUsage(const char code[])
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue