* Fix #10928, #10930 FP constStatement * Fix test cases (first one did not compile)
This commit is contained in:
parent
401f0de18b
commit
63d96e49fc
|
@ -1748,7 +1748,7 @@ bool isConstExpression(const Token *tok, const Library& library, bool pure, bool
|
||||||
return isConstExpression(tok->astOperand1(), library, pure, cpp) && isConstExpression(tok->astOperand2(), library, pure, cpp);
|
return isConstExpression(tok->astOperand1(), library, pure, cpp) && isConstExpression(tok->astOperand2(), library, pure, cpp);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool isWithoutSideEffects(bool cpp, const Token* tok, bool checkArrayAccess)
|
bool isWithoutSideEffects(bool cpp, const Token* tok, bool checkArrayAccess, bool checkReference)
|
||||||
{
|
{
|
||||||
if (!cpp)
|
if (!cpp)
|
||||||
return true;
|
return true;
|
||||||
|
@ -1757,7 +1757,7 @@ bool isWithoutSideEffects(bool cpp, const Token* tok, bool checkArrayAccess)
|
||||||
tok = tok->astOperand2();
|
tok = tok->astOperand2();
|
||||||
if (tok && tok->varId()) {
|
if (tok && tok->varId()) {
|
||||||
const Variable* var = tok->variable();
|
const Variable* var = tok->variable();
|
||||||
return var && (!var->isClass() || var->isPointer() || (checkArrayAccess ? var->isStlType() && !var->isStlType(CheckClass::stl_containers_not_const) : var->isStlType()));
|
return var && ((!var->isClass() && (checkReference || !var->isReference())) || var->isPointer() || (checkArrayAccess ? var->isStlType() && !var->isStlType(CheckClass::stl_containers_not_const) : var->isStlType()));
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -227,7 +227,7 @@ bool isConstFunctionCall(const Token* ftok, const Library& library);
|
||||||
|
|
||||||
bool isConstExpression(const Token *tok, const Library& library, bool pure, bool cpp);
|
bool isConstExpression(const Token *tok, const Library& library, bool pure, bool cpp);
|
||||||
|
|
||||||
bool isWithoutSideEffects(bool cpp, const Token* tok, bool checkArrayAccess = false);
|
bool isWithoutSideEffects(bool cpp, const Token* tok, bool checkArrayAccess = false, bool checkReference = true);
|
||||||
|
|
||||||
bool isUniqueExpression(const Token* tok);
|
bool isUniqueExpression(const Token* tok);
|
||||||
|
|
||||||
|
|
|
@ -1771,6 +1771,8 @@ static bool isConstStatement(const Token *tok, bool cpp)
|
||||||
return false;
|
return false;
|
||||||
if (tok->astTop() && Token::simpleMatch(tok->astTop()->astOperand1(), "delete"))
|
if (tok->astTop() && Token::simpleMatch(tok->astTop()->astOperand1(), "delete"))
|
||||||
return false;
|
return false;
|
||||||
|
if (Token::Match(tok, "&&|%oror%"))
|
||||||
|
return isConstStatement(tok->astOperand1(), cpp) && isConstStatement(tok->astOperand2(), cpp);
|
||||||
if (Token::Match(tok, "!|~|%cop%") && (tok->astOperand1() || tok->astOperand2()))
|
if (Token::Match(tok, "!|~|%cop%") && (tok->astOperand1() || tok->astOperand2()))
|
||||||
return true;
|
return true;
|
||||||
if (Token::simpleMatch(tok->previous(), "sizeof ("))
|
if (Token::simpleMatch(tok->previous(), "sizeof ("))
|
||||||
|
@ -1785,7 +1787,7 @@ static bool isConstStatement(const Token *tok, bool cpp)
|
||||||
return tok->astParent() ? isConstStatement(tok->astOperand1(), cpp) && isConstStatement(tok->astOperand2(), cpp) : isConstStatement(tok->astOperand2(), cpp);
|
return tok->astParent() ? isConstStatement(tok->astOperand1(), cpp) && isConstStatement(tok->astOperand2(), cpp) : isConstStatement(tok->astOperand2(), cpp);
|
||||||
if (Token::simpleMatch(tok, "?") && Token::simpleMatch(tok->astOperand2(), ":")) // ternary operator
|
if (Token::simpleMatch(tok, "?") && Token::simpleMatch(tok->astOperand2(), ":")) // ternary operator
|
||||||
return isConstStatement(tok->astOperand1(), cpp) && isConstStatement(tok->astOperand2()->astOperand1(), cpp) && isConstStatement(tok->astOperand2()->astOperand2(), cpp);
|
return isConstStatement(tok->astOperand1(), cpp) && isConstStatement(tok->astOperand2()->astOperand1(), cpp) && isConstStatement(tok->astOperand2()->astOperand2(), cpp);
|
||||||
if (isBracketAccess(tok) && isWithoutSideEffects(cpp, tok->astOperand1(), /*checkArrayAccess*/ true)) {
|
if (isBracketAccess(tok) && isWithoutSideEffects(cpp, tok->astOperand1(), /*checkArrayAccess*/ true, /*checkReference*/ false)) {
|
||||||
if (Token::simpleMatch(tok->astParent(), "["))
|
if (Token::simpleMatch(tok->astParent(), "["))
|
||||||
return isConstStatement(tok->astOperand2(), cpp) && isConstStatement(tok->astParent(), cpp);
|
return isConstStatement(tok->astOperand2(), cpp) && isConstStatement(tok->astParent(), cpp);
|
||||||
return isConstStatement(tok->astOperand2(), cpp);
|
return isConstStatement(tok->astOperand2(), cpp);
|
||||||
|
|
|
@ -517,7 +517,7 @@ private:
|
||||||
"[test.cpp:12]: (warning) Redundant code: Found unused array access.\n",
|
"[test.cpp:12]: (warning) Redundant code: Found unused array access.\n",
|
||||||
errout.str());
|
errout.str());
|
||||||
|
|
||||||
check("void g() {\n"
|
check("void g(std::map<std::string, std::string>& map) {\n"
|
||||||
" int j[2]{};\n"
|
" int j[2]{};\n"
|
||||||
" int k[2] = {};\n"
|
" int k[2] = {};\n"
|
||||||
" int l[]{ 1, 2 };\n"
|
" int l[]{ 1, 2 };\n"
|
||||||
|
@ -531,6 +531,7 @@ private:
|
||||||
" j[0][0][h()];\n"
|
" j[0][0][h()];\n"
|
||||||
" std::map<std::string, int> M;\n"
|
" std::map<std::string, int> M;\n"
|
||||||
" M[\"abc\"];\n"
|
" M[\"abc\"];\n"
|
||||||
|
" map[\"abc\"];\n" // #10928
|
||||||
" std::auto_ptr<Int> app[4];" // #10919
|
" std::auto_ptr<Int> app[4];" // #10919
|
||||||
"}\n");
|
"}\n");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
@ -608,6 +609,13 @@ private:
|
||||||
" params_given (params, \"overrides\") || (overrides = \"1\");\n"
|
" params_given (params, \"overrides\") || (overrides = \"1\");\n"
|
||||||
"}", true);
|
"}", true);
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
|
check("void f(std::ifstream& file) {\n" // #10930
|
||||||
|
" int a{}, b{};\n"
|
||||||
|
" (file >> a) || (file >> b);\n"
|
||||||
|
" (file >> a) && (file >> b);\n"
|
||||||
|
"}\n", true);
|
||||||
|
ASSERT_EQUALS("", errout.str());
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -4396,7 +4396,7 @@ private:
|
||||||
" {\n"
|
" {\n"
|
||||||
" x = y = z = 0.0;\n"
|
" x = y = z = 0.0;\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
" V( double x, const double y, const double &z )\n"
|
" V( double x, const double y_, const double &z_)\n"
|
||||||
" {\n"
|
" {\n"
|
||||||
" x = x; y = y; z = z;\n"
|
" x = x; y = y; z = z;\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
|
|
Loading…
Reference in New Issue