parent
df99d8aa0a
commit
25ad22c6af
|
@ -1443,7 +1443,7 @@ bool isVariableChanged(const Token *tok, int indirect, const Settings *settings,
|
||||||
return false;
|
return false;
|
||||||
const Token *tok2 = tok;
|
const Token *tok2 = tok;
|
||||||
int derefs = 0;
|
int derefs = 0;
|
||||||
while (Token::simpleMatch(tok2->astParent(), "*") ||
|
while (Token::simpleMatch(tok2->astParent(), "*") ||
|
||||||
(Token::simpleMatch(tok2->astParent(), ".") && !Token::simpleMatch(tok2->astParent()->astParent(), "(")) ||
|
(Token::simpleMatch(tok2->astParent(), ".") && !Token::simpleMatch(tok2->astParent()->astParent(), "(")) ||
|
||||||
(Token::simpleMatch(tok2->astParent(), "[") && tok2 == tok2->astParent()->astOperand1())) {
|
(Token::simpleMatch(tok2->astParent(), "[") && tok2 == tok2->astParent()->astOperand1())) {
|
||||||
if (Token::simpleMatch(tok2->astParent(), "*") || tok2->astParent()->originalName() == "->")
|
if (Token::simpleMatch(tok2->astParent(), "*") || tok2->astParent()->originalName() == "->")
|
||||||
|
|
|
@ -425,7 +425,7 @@ static std::list<std::pair<const Token *, MathLib::bigint>> getUnsafeFunction(co
|
||||||
if (Token::findmatch(tok2->link(), "return|throw", tok2))
|
if (Token::findmatch(tok2->link(), "return|throw", tok2))
|
||||||
return ret;
|
return ret;
|
||||||
int indirect = 0;
|
int indirect = 0;
|
||||||
if(argvar->valueType())
|
if (argvar->valueType())
|
||||||
indirect = argvar->valueType()->pointer;
|
indirect = argvar->valueType()->pointer;
|
||||||
if (isVariableChanged(tok2->link(), tok2, indirect, argvar->declarationId(), false, settings, tokenizer->isCPP()))
|
if (isVariableChanged(tok2->link(), tok2, indirect, argvar->declarationId(), false, settings, tokenizer->isCPP()))
|
||||||
return ret;
|
return ret;
|
||||||
|
|
|
@ -2490,7 +2490,9 @@ struct SingleValueFlowForwardAnalyzer : ValueFlowForwardAnalyzer {
|
||||||
virtual bool isAlias(const Token* tok) const OVERRIDE {
|
virtual bool isAlias(const Token* tok) const OVERRIDE {
|
||||||
if (value.isLifetimeValue())
|
if (value.isLifetimeValue())
|
||||||
return false;
|
return false;
|
||||||
for(const auto& m:{std::ref(getVars()), std::ref(getAliasedVars())}) {
|
for (const auto& m: {
|
||||||
|
std::ref(getVars()), std::ref(getAliasedVars())
|
||||||
|
}) {
|
||||||
for (const auto& p:m.get()) {
|
for (const auto& p:m.get()) {
|
||||||
nonneg int varid = p.first;
|
nonneg int varid = p.first;
|
||||||
const Variable* var = p.second;
|
const Variable* var = p.second;
|
||||||
|
@ -2567,7 +2569,7 @@ struct VariableForwardAnalyzer : SingleValueFlowForwardAnalyzer {
|
||||||
VariableForwardAnalyzer(const Variable* v, const ValueFlow::Value& val, std::vector<const Variable*> paliases, const TokenList* t)
|
VariableForwardAnalyzer(const Variable* v, const ValueFlow::Value& val, std::vector<const Variable*> paliases, const TokenList* t)
|
||||||
: SingleValueFlowForwardAnalyzer(val, t), var(v) {
|
: SingleValueFlowForwardAnalyzer(val, t), var(v) {
|
||||||
varids[var->declarationId()] = var;
|
varids[var->declarationId()] = var;
|
||||||
for(const Variable* av:paliases) {
|
for (const Variable* av:paliases) {
|
||||||
if (!av)
|
if (!av)
|
||||||
continue;
|
continue;
|
||||||
aliases[av->declarationId()] = av;
|
aliases[av->declarationId()] = av;
|
||||||
|
@ -2616,10 +2618,10 @@ static bool valueFlowForwardVariable(Token* const startToken,
|
||||||
{
|
{
|
||||||
std::vector<const Variable*> aliases;
|
std::vector<const Variable*> aliases;
|
||||||
for (const ValueFlow::Value& v : values) {
|
for (const ValueFlow::Value& v : values) {
|
||||||
if (!v.tokvalue)
|
if (!v.tokvalue)
|
||||||
continue;
|
continue;
|
||||||
const Token* lifeTok = nullptr;
|
const Token* lifeTok = nullptr;
|
||||||
for(const ValueFlow::Value& lv:v.tokvalue->values()) {
|
for (const ValueFlow::Value& lv:v.tokvalue->values()) {
|
||||||
if (!lv.isLocalLifetimeValue())
|
if (!lv.isLocalLifetimeValue())
|
||||||
continue;
|
continue;
|
||||||
if (lifeTok) {
|
if (lifeTok) {
|
||||||
|
|
|
@ -4174,7 +4174,7 @@ private:
|
||||||
" A *b = v.back();\n"
|
" A *b = v.back();\n"
|
||||||
" v.pop_back();\n"
|
" v.pop_back();\n"
|
||||||
" delete b;\n"
|
" delete b;\n"
|
||||||
"}\n" ,true);
|
"}\n",true);
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("struct A {};\n"
|
check("struct A {};\n"
|
||||||
|
@ -4185,7 +4185,7 @@ private:
|
||||||
" A *b = v.back();\n"
|
" A *b = v.back();\n"
|
||||||
" v.pop_back();\n"
|
" v.pop_back();\n"
|
||||||
" delete b;\n"
|
" delete b;\n"
|
||||||
"}\n" ,true);
|
"}\n",true);
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("struct A {};\n"
|
check("struct A {};\n"
|
||||||
|
@ -4196,7 +4196,7 @@ private:
|
||||||
" std::shared_ptr<A> b = v.back();\n"
|
" std::shared_ptr<A> b = v.back();\n"
|
||||||
" v.pop_back();\n"
|
" v.pop_back();\n"
|
||||||
" delete b;\n"
|
" delete b;\n"
|
||||||
"}\n" ,true);
|
"}\n",true);
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue