Fix #1007 (False positive array index out of bounds concerning a switch statement in a for loop)
Bailout if switch is found in for loop. http://sourceforge.net/apps/trac/cppcheck/ticket/1007
This commit is contained in:
parent
4e340d556d
commit
12a87fa3a4
|
@ -397,7 +397,7 @@ void CheckBufferOverrun::checkScope(const Token *tok, const char *varname[], con
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tok2->str() == "if")
|
if (Token::Match(tok2, "if|switch"))
|
||||||
{
|
{
|
||||||
// Bailout
|
// Bailout
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -93,6 +93,7 @@ private:
|
||||||
TEST_CASE(array_index_22);
|
TEST_CASE(array_index_22);
|
||||||
TEST_CASE(array_index_23);
|
TEST_CASE(array_index_23);
|
||||||
TEST_CASE(array_index_multidim);
|
TEST_CASE(array_index_multidim);
|
||||||
|
TEST_CASE(array_index_switch_in_for);
|
||||||
|
|
||||||
TEST_CASE(buffer_overrun_1);
|
TEST_CASE(buffer_overrun_1);
|
||||||
TEST_CASE(buffer_overrun_2);
|
TEST_CASE(buffer_overrun_2);
|
||||||
|
@ -753,6 +754,45 @@ private:
|
||||||
TODO_ASSERT_EQUALS("[test.cpp:4]: (error) Array index out of bounds\n", errout.str());
|
TODO_ASSERT_EQUALS("[test.cpp:4]: (error) Array index out of bounds\n", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void array_index_switch_in_for()
|
||||||
|
{
|
||||||
|
check("void f()\n"
|
||||||
|
"{\n"
|
||||||
|
" int ar[10];\n"
|
||||||
|
" for (int i = 0; i < 10; ++i)\n"
|
||||||
|
" {\n"
|
||||||
|
" switch(i)\n"
|
||||||
|
" {\n"
|
||||||
|
" case 9:\n"
|
||||||
|
" ar[i] = 0;\n"
|
||||||
|
" break;\n"
|
||||||
|
" default:\n"
|
||||||
|
" ar[i] = ar[i+1];\n"
|
||||||
|
" break;\n"
|
||||||
|
" };\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n");
|
||||||
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
|
check("void f()\n"
|
||||||
|
"{\n"
|
||||||
|
" int ar[10];\n"
|
||||||
|
" for (int i = 0; i < 10; ++i)\n"
|
||||||
|
" {\n"
|
||||||
|
" switch(i)\n"
|
||||||
|
" {\n"
|
||||||
|
" case 8:\n"
|
||||||
|
" ar[i] = 0;\n"
|
||||||
|
" break;\n"
|
||||||
|
" default:\n"
|
||||||
|
" ar[i] = ar[i+1];\n"
|
||||||
|
" break;\n"
|
||||||
|
" };\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n");
|
||||||
|
TODO_ASSERT_EQUALS("[test.cpp:12]: (error) Array index out of bounds\n", errout.str());
|
||||||
|
}
|
||||||
|
|
||||||
void buffer_overrun_1()
|
void buffer_overrun_1()
|
||||||
{
|
{
|
||||||
check("void f()\n"
|
check("void f()\n"
|
||||||
|
|
Loading…
Reference in New Issue