Fixed #354 (false positive: memory leak)
This commit is contained in:
parent
21e0639443
commit
d0f3dccc6d
|
@ -657,10 +657,17 @@ Token *CheckMemoryLeakClass::getcode(const Token *tok, std::list<const Token *>
|
||||||
|
|
||||||
else if (Token::simpleMatch(tok->next(), "("))
|
else if (Token::simpleMatch(tok->next(), "("))
|
||||||
{
|
{
|
||||||
|
int parlevel = 1;
|
||||||
for (const Token *tok2 = tok->tokAt(2); tok2; tok2 = tok2->next())
|
for (const Token *tok2 = tok->tokAt(2); tok2; tok2 = tok2->next())
|
||||||
{
|
{
|
||||||
if (tok2->str() == "(" || tok2->str() == ")")
|
if (tok2->str() == "(")
|
||||||
break;
|
++parlevel;
|
||||||
|
else if (tok2->str() == ")")
|
||||||
|
{
|
||||||
|
if (parlevel <= 1)
|
||||||
|
break;
|
||||||
|
--parlevel;
|
||||||
|
}
|
||||||
|
|
||||||
if (tok2->str() == varname)
|
if (tok2->str() == varname)
|
||||||
{
|
{
|
||||||
|
|
|
@ -123,6 +123,7 @@ private:
|
||||||
TEST_CASE(ret5); // Bug 2458436 - return use
|
TEST_CASE(ret5); // Bug 2458436 - return use
|
||||||
TEST_CASE(ret6);
|
TEST_CASE(ret6);
|
||||||
TEST_CASE(ret7);
|
TEST_CASE(ret7);
|
||||||
|
TEST_CASE(ret8);
|
||||||
|
|
||||||
TEST_CASE(mismatch1);
|
TEST_CASE(mismatch1);
|
||||||
TEST_CASE(mismatch2);
|
TEST_CASE(mismatch2);
|
||||||
|
@ -1094,6 +1095,16 @@ private:
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ret8()
|
||||||
|
{
|
||||||
|
check("char *foo()\n"
|
||||||
|
"{\n"
|
||||||
|
" char *c = new char[50];\n"
|
||||||
|
" return ((char *)(c+1));\n"
|
||||||
|
"}\n");
|
||||||
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void mismatch1()
|
void mismatch1()
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue