Skip to content

Commit fa72ec2

Browse files
committed
Uninitialized variables; avoid false positives when passing uninitialized variable to unknown function
1 parent a2e709a commit fa72ec2

File tree

2 files changed

+8
-0
lines changed

2 files changed

+8
-0
lines changed

lib/checkuninitvar.cpp

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1511,6 +1511,8 @@ void CheckUninitVar::valueFlowUninit()
15111511
continue;
15121512
if (v->indirect > 1 || v->indirect < 0)
15131513
continue;
1514+
if (v->indirect == 0 && tok->valueType() && tok->valueType()->pointer == 0 && !isVariableUsage(tok, false, NO_ALLOC, 0))
1515+
continue;
15141516
bool uninitderef = false;
15151517
if (tok->variable()) {
15161518
bool unknown;

test/testuninitvar.cpp

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -4601,6 +4601,12 @@ class TestUninitVar : public TestFixture {
46014601
"}\n");
46024602
ASSERT_EQUALS("", errout.str());
46034603

4604+
valueFlowUninit("void json_parse_nat_type_flags(json_t *root) {\n"
4605+
" int index;\n"
4606+
" json_array_foreach(root, index, value) {}\n"
4607+
"}");
4608+
ASSERT_EQUALS("", errout.str());
4609+
46044610
valueFlowUninit("int foo()\n"
46054611
"{\n"
46064612
" int i;\n"

0 commit comments

Comments
 (0)