Merge branch 'master' of github.com:danmar/cppcheck
This commit is contained in:
commit
9a52b35144
|
@ -1634,7 +1634,6 @@ void CheckOther::functionVariableUsage()
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Variables::VariableUsage *var = variables.find(varid1);
|
Variables::VariableUsage *var = variables.find(varid1);
|
||||||
|
|
||||||
if (var && var->_type == Variables::reference)
|
if (var && var->_type == Variables::reference)
|
||||||
{
|
{
|
||||||
variables.writeAliases(varid1);
|
variables.writeAliases(varid1);
|
||||||
|
@ -1642,6 +1641,13 @@ void CheckOther::functionVariableUsage()
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
variables.write(varid1);
|
variables.write(varid1);
|
||||||
|
|
||||||
|
Variables::VariableUsage *var2 = variables.find(tok->varId());
|
||||||
|
if (var2 && var2->_type == Variables::reference)
|
||||||
|
{
|
||||||
|
variables.writeAliases(tok->varId());
|
||||||
|
variables.read(tok->varId());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const Token *equal = tok->next();
|
const Token *equal = tok->next();
|
||||||
|
|
|
@ -3403,7 +3403,7 @@ void Tokenizer::simplifySizeof()
|
||||||
{
|
{
|
||||||
Token tempTok(0);
|
Token tempTok(0);
|
||||||
tempTok.str("*");
|
tempTok.str("*");
|
||||||
sizeOfVar[varId] = MathLib::toString<long>(sizeOfType(&tempTok));
|
sizeOfVar[varId] = MathLib::toString<unsigned long>(sizeOfType(&tempTok));
|
||||||
}
|
}
|
||||||
|
|
||||||
else if (Token::Match(tok->tokAt(-1), "%type% %var% [ ] = %str% ;"))
|
else if (Token::Match(tok->tokAt(-1), "%type% %var% [ ] = %str% ;"))
|
||||||
|
@ -3547,7 +3547,7 @@ void Tokenizer::simplifySizeof()
|
||||||
|
|
||||||
if (Token::Match(tok->next(), "( * )"))
|
if (Token::Match(tok->next(), "( * )"))
|
||||||
{
|
{
|
||||||
tok->str(MathLib::toString<long>(sizeOfType(tok->tokAt(2))));
|
tok->str(MathLib::toString<unsigned long>(sizeOfType(tok->tokAt(2))));
|
||||||
Token::eraseTokens(tok, tok->tokAt(4));
|
Token::eraseTokens(tok, tok->tokAt(4));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -81,6 +81,7 @@ private:
|
||||||
TEST_CASE(localvaralias7); // ticket #1732
|
TEST_CASE(localvaralias7); // ticket #1732
|
||||||
TEST_CASE(localvaralias8);
|
TEST_CASE(localvaralias8);
|
||||||
TEST_CASE(localvaralias9); // ticket #1996
|
TEST_CASE(localvaralias9); // ticket #1996
|
||||||
|
TEST_CASE(localvaralias10); // ticket #2004
|
||||||
TEST_CASE(localvarasm);
|
TEST_CASE(localvarasm);
|
||||||
TEST_CASE(localvarstatic);
|
TEST_CASE(localvarstatic);
|
||||||
|
|
||||||
|
@ -2146,6 +2147,17 @@ private:
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void localvaralias10() // ticket 2004
|
||||||
|
{
|
||||||
|
functionVariableUsage("void foo(Foo &foo)\n"
|
||||||
|
"{\n"
|
||||||
|
" Foo &ref = foo;\n"
|
||||||
|
" int *x = &ref.x();\n"
|
||||||
|
" *x = 0;\n"
|
||||||
|
"}");
|
||||||
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
}
|
||||||
|
|
||||||
void localvarasm()
|
void localvarasm()
|
||||||
{
|
{
|
||||||
functionVariableUsage("void foo(int &b)\n"
|
functionVariableUsage("void foo(int &b)\n"
|
||||||
|
|
Loading…
Reference in New Issue