CheckMemoryLeak: Small fixes and updates
This commit is contained in:
parent
a8ba28440c
commit
7708c2c1d1
|
@ -106,6 +106,8 @@ static void CheckMemoryLeak_CheckScope( const TOKEN *Tok1, const char varname[]
|
|||
|
||||
int alloc_indentlevel = 0;
|
||||
|
||||
bool isif = false;
|
||||
|
||||
int indentlevel = 0;
|
||||
for (const TOKEN *tok = Tok1 ; tok; tok = tok->next )
|
||||
{
|
||||
|
@ -128,6 +130,7 @@ static void CheckMemoryLeak_CheckScope( const TOKEN *Tok1, const char varname[]
|
|||
|
||||
// Skip stuff like: if (!var) ...
|
||||
if ( Match(tok, "if ( ! %var1% )", varnames) ||
|
||||
Match(tok, "if ( unlikely( ! %var1% ) )", varnames) ||
|
||||
Match(tok, "if ( %var1% == NULL )", varnames) ||
|
||||
Match(tok, "if ( NULL == %var1% )", varnames) ||
|
||||
Match(tok, "if ( %var1% == 0 )", varnames) )
|
||||
|
@ -149,6 +152,12 @@ static void CheckMemoryLeak_CheckScope( const TOKEN *Tok1, const char varname[]
|
|||
}
|
||||
}
|
||||
|
||||
// if..
|
||||
if ( Match(tok,"if") )
|
||||
isif = true;
|
||||
if ( strchr(";{}", tok->str[0]) )
|
||||
isif = false;
|
||||
|
||||
// Allocated..
|
||||
if ( Match(tok, "%var1% =", varnames) )
|
||||
{
|
||||
|
@ -157,6 +166,28 @@ static void CheckMemoryLeak_CheckScope( const TOKEN *Tok1, const char varname[]
|
|||
{
|
||||
Alloc = alloc;
|
||||
alloc_indentlevel = indentlevel;
|
||||
|
||||
if ( isif )
|
||||
{
|
||||
while ( tok )
|
||||
{
|
||||
if ( tok->str[0] == '{' )
|
||||
{
|
||||
indentlevel++;
|
||||
}
|
||||
else if ( tok->str[0] == '}' )
|
||||
{
|
||||
indentlevel--;
|
||||
if ( indentlevel <= alloc_indentlevel )
|
||||
break;
|
||||
}
|
||||
else if ( tok->str[0] == ';' && indentlevel == alloc_indentlevel )
|
||||
{
|
||||
break;
|
||||
}
|
||||
tok = tok->next;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -176,6 +207,9 @@ static void CheckMemoryLeak_CheckScope( const TOKEN *Tok1, const char varname[]
|
|||
// foo( var1 );
|
||||
if ( Match( tok, "[=,(] %var1% [,);]", varnames ) )
|
||||
return;
|
||||
if ( Match( tok, "= ( %type% * ) %var1% ;", varnames ) )
|
||||
return;
|
||||
|
||||
|
||||
// continue/break loop..
|
||||
if (Alloc != No &&
|
||||
|
|
20
tests.cpp
20
tests.cpp
|
@ -627,6 +627,26 @@ static void memleak_in_function()
|
|||
" return NULL;\n"
|
||||
"}\n";
|
||||
check( CheckMemoryLeak, __LINE__, test16, "[test.cpp:8]: Memory leak: s\n" );
|
||||
|
||||
|
||||
const char test17[] = "static void f()\n"
|
||||
"{\n"
|
||||
" char *str = strdup(\"hello\");\n"
|
||||
" char *str2 = (char *)str;\n"
|
||||
" free(str2);\n"
|
||||
"}\n";
|
||||
check( CheckMemoryLeak, __LINE__, test17, "" );
|
||||
|
||||
|
||||
const char test18[] = "static void f()\n"
|
||||
"{\n"
|
||||
" char *str;\n"
|
||||
" if ((str = (char *)malloc(123,33)) == NULL)\n"
|
||||
" return;\n"
|
||||
" free(str);\n"
|
||||
"}\n";
|
||||
check( CheckMemoryLeak, __LINE__, test18, "" );
|
||||
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
|
||||
|
|
Loading…
Reference in New Issue