fix #2765 (Non local address detected as address of local auto-variable)
This commit is contained in:
parent
ccb831d375
commit
bb5dfa58a1
|
@ -53,7 +53,7 @@ bool CheckAutoVariables::isAutoVar(unsigned int varId)
|
||||||
{
|
{
|
||||||
const Variable *var = _tokenizer->getSymbolDatabase()->getVariableFromVarId(varId);
|
const Variable *var = _tokenizer->getSymbolDatabase()->getVariableFromVarId(varId);
|
||||||
|
|
||||||
if (!var || !var->isLocal() || var->isStatic() || var->isArray())
|
if (!var || !var->isLocal() || var->isStatic() || var->isArray() || var->typeEndToken()->str() == "*")
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
@ -98,7 +98,7 @@ void CheckAutoVariables::autoVariables()
|
||||||
if (Token::Match(tok, "[;{}] * %var% = & %var%") && errorAv(tok->tokAt(2), tok->tokAt(5)))
|
if (Token::Match(tok, "[;{}] * %var% = & %var%") && errorAv(tok->tokAt(2), tok->tokAt(5)))
|
||||||
{
|
{
|
||||||
const Variable * var = symbolDatabase->getVariableFromVarId(tok->tokAt(5)->varId());
|
const Variable * var = symbolDatabase->getVariableFromVarId(tok->tokAt(5)->varId());
|
||||||
if (var && (!var->isClass() || var->type()))
|
if (var && (!var->isClass() || var->type()))
|
||||||
errorAutoVariableAssignment(tok);
|
errorAutoVariableAssignment(tok);
|
||||||
}
|
}
|
||||||
else if (Token::Match(tok, "[;{}] %var% [ %any% ] = & %var%") && errorAv(tok->tokAt(1), tok->tokAt(7)))
|
else if (Token::Match(tok, "[;{}] %var% [ %any% ] = & %var%") && errorAv(tok->tokAt(1), tok->tokAt(7)))
|
||||||
|
|
|
@ -75,7 +75,8 @@ private:
|
||||||
TEST_CASE(testautovar_return2);
|
TEST_CASE(testautovar_return2);
|
||||||
TEST_CASE(testautovar_extern);
|
TEST_CASE(testautovar_extern);
|
||||||
TEST_CASE(testinvaliddealloc);
|
TEST_CASE(testinvaliddealloc);
|
||||||
TEST_CASE(testassign); // Ticket #1819
|
TEST_CASE(testassign1); // Ticket #1819
|
||||||
|
TEST_CASE(testassign2); // Ticket #2765
|
||||||
|
|
||||||
TEST_CASE(returnLocalVariable1);
|
TEST_CASE(returnLocalVariable1);
|
||||||
TEST_CASE(returnLocalVariable2);
|
TEST_CASE(returnLocalVariable2);
|
||||||
|
@ -230,7 +231,7 @@ private:
|
||||||
ASSERT_EQUALS(std::string(""), errout.str());
|
ASSERT_EQUALS(std::string(""), errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
void testassign()
|
void testassign1() // Ticket #1819
|
||||||
{
|
{
|
||||||
check("void f(EventPtr *eventP, ActionPtr **actionsP) {\n"
|
check("void f(EventPtr *eventP, ActionPtr **actionsP) {\n"
|
||||||
" EventPtr event = *eventP;\n"
|
" EventPtr event = *eventP;\n"
|
||||||
|
@ -239,6 +240,15 @@ private:
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void testassign2() // Ticket #2765
|
||||||
|
{
|
||||||
|
check("static void function(unsigned long **datap) {\n"
|
||||||
|
" struct my_s *mr = global_structure_pointer;\n"
|
||||||
|
" *datap = &mr->value;\n"
|
||||||
|
"}\n");
|
||||||
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
}
|
||||||
|
|
||||||
void returnLocalVariable1()
|
void returnLocalVariable1()
|
||||||
{
|
{
|
||||||
check("char *foo()\n"
|
check("char *foo()\n"
|
||||||
|
|
Loading…
Reference in New Issue