Removed "verify" code in testrunner. Fixing its messages reduces the accuracy of the test suite.
This commit is contained in:
parent
b0df668975
commit
176b3925b3
|
@ -49,11 +49,7 @@ private:
|
||||||
checkAutoVariables.assignFunctionArg();
|
checkAutoVariables.assignFunctionArg();
|
||||||
|
|
||||||
if (runSimpleChecks) {
|
if (runSimpleChecks) {
|
||||||
const std::string str1(tokenizer.tokens()->stringifyList(0,true));
|
|
||||||
tokenizer.simplifyTokenList2();
|
tokenizer.simplifyTokenList2();
|
||||||
const std::string str2(tokenizer.tokens()->stringifyList(0,true));
|
|
||||||
if (str1 != str2)
|
|
||||||
warnUnsimplified(str1, str2);
|
|
||||||
|
|
||||||
// Check auto variables
|
// Check auto variables
|
||||||
checkAutoVariables.autoVariables();
|
checkAutoVariables.autoVariables();
|
||||||
|
|
|
@ -43,11 +43,7 @@ private:
|
||||||
Tokenizer tokenizer(&settings, this);
|
Tokenizer tokenizer(&settings, this);
|
||||||
std::istringstream istr(code);
|
std::istringstream istr(code);
|
||||||
tokenizer.tokenize(istr, "test.cpp");
|
tokenizer.tokenize(istr, "test.cpp");
|
||||||
const std::string str1(tokenizer.tokens()->stringifyList(0,true));
|
|
||||||
tokenizer.simplifyTokenList2();
|
tokenizer.simplifyTokenList2();
|
||||||
const std::string str2(tokenizer.tokens()->stringifyList(0,true));
|
|
||||||
if (str1 != str2)
|
|
||||||
warnUnsimplified(str1, str2);
|
|
||||||
|
|
||||||
// Check..
|
// Check..
|
||||||
CheckBoost checkBoost;
|
CheckBoost checkBoost;
|
||||||
|
|
|
@ -31,7 +31,7 @@ public:
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
void check(const char code[], bool experimental = true, const char filename[] = "test.cpp", bool verify = true) {
|
void check(const char code[], bool experimental = true, const char filename[] = "test.cpp") {
|
||||||
// Clear the error buffer..
|
// Clear the error buffer..
|
||||||
errout.str("");
|
errout.str("");
|
||||||
|
|
||||||
|
@ -46,19 +46,8 @@ private:
|
||||||
Tokenizer tokenizer(&settings, this);
|
Tokenizer tokenizer(&settings, this);
|
||||||
std::istringstream istr(code);
|
std::istringstream istr(code);
|
||||||
tokenizer.tokenize(istr, filename);
|
tokenizer.tokenize(istr, filename);
|
||||||
|
|
||||||
const std::string str1(tokenizer.tokens()->stringifyList(0,true));
|
|
||||||
|
|
||||||
// Assign variable ids
|
|
||||||
tokenizer.simplifyTokenList2();
|
tokenizer.simplifyTokenList2();
|
||||||
|
|
||||||
const std::string str2(tokenizer.tokens()->stringifyList(0,true));
|
|
||||||
|
|
||||||
// Ensure that the test case is not bad.
|
|
||||||
if (verify && str1 != str2) {
|
|
||||||
warnUnsimplified(str1, str2);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check for buffer overruns..
|
// Check for buffer overruns..
|
||||||
CheckBufferOverrun checkBufferOverrun;
|
CheckBufferOverrun checkBufferOverrun;
|
||||||
checkBufferOverrun.runSimplifiedChecks(&tokenizer, &settings, this);
|
checkBufferOverrun.runSimplifiedChecks(&tokenizer, &settings, this);
|
||||||
|
@ -1845,7 +1834,7 @@ private:
|
||||||
" }\n"
|
" }\n"
|
||||||
" a[i - 1] = 0;\n"
|
" a[i - 1] = 0;\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
"}", true, "test.cpp", false);
|
"}", true);
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
|
@ -2049,21 +2038,21 @@ private:
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
" char str[3];\n"
|
" char str[3];\n"
|
||||||
" str[((unsigned char)3) - 1] = 0;\n"
|
" str[((unsigned char)3) - 1] = 0;\n"
|
||||||
"}", false, "test.cpp", false);
|
"}", false, "test.cpp");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void f() {\n" // #5416 FP
|
check("void f() {\n" // #5416 FP
|
||||||
" char *str[3];\n"
|
" char *str[3];\n"
|
||||||
" do_something(&str[0][5]);\n"
|
" do_something(&str[0][5]);\n"
|
||||||
"}", false, "test.cpp", false);
|
"}", false, "test.cpp");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("class X { static const int x[100]; };\n" // #6070
|
check("class X { static const int x[100]; };\n" // #6070
|
||||||
"const int X::x[100] = {0};", false, "test.cpp", false);
|
"const int X::x[100] = {0};", false, "test.cpp");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("namespace { class X { static const int x[100]; };\n" // #6232
|
check("namespace { class X { static const int x[100]; };\n" // #6232
|
||||||
"const int X::x[100] = {0}; }", false, "test.cpp", false);
|
"const int X::x[100] = {0}; }", false, "test.cpp");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2647,7 +2636,7 @@ private:
|
||||||
check("void f() {\n" // #6350 - fp when there is cast of buffer
|
check("void f() {\n" // #6350 - fp when there is cast of buffer
|
||||||
" wchar_t buf[64];\n"
|
" wchar_t buf[64];\n"
|
||||||
" p = (unsigned char *) buf + sizeof (buf);\n"
|
" p = (unsigned char *) buf + sizeof (buf);\n"
|
||||||
"}", false, "6350.c", false);
|
"}", false, "6350.c");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2856,7 +2845,7 @@ private:
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
" int *tab4 = malloc(20 * sizeof(int));\n"
|
" int *tab4 = malloc(20 * sizeof(int));\n"
|
||||||
" tab4[20] = 0;\n"
|
" tab4[20] = 0;\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:3]: (error) Array 'tab4[20]' accessed at index 20, which is out of bounds.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3]: (error) Array 'tab4[20]' accessed at index 20, which is out of bounds.\n", errout.str());
|
||||||
|
|
||||||
// ticket #1134
|
// ticket #1134
|
||||||
|
@ -2864,7 +2853,7 @@ private:
|
||||||
" int *x, i;\n"
|
" int *x, i;\n"
|
||||||
" x = malloc(10 * sizeof(int));\n"
|
" x = malloc(10 * sizeof(int));\n"
|
||||||
" x[10] = 0;\n"
|
" x[10] = 0;\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:4]: (error) Array 'x[10]' accessed at index 10, which is out of bounds.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:4]: (error) Array 'x[10]' accessed at index 10, which is out of bounds.\n", errout.str());
|
||||||
|
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
|
@ -2874,7 +2863,7 @@ private:
|
||||||
" tab4 = malloc(21 * sizeof(int));\n"
|
" tab4 = malloc(21 * sizeof(int));\n"
|
||||||
" tab4[20] = 0;\n"
|
" tab4[20] = 0;\n"
|
||||||
" free(tab4);\n"
|
" free(tab4);\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
|
@ -2883,7 +2872,7 @@ private:
|
||||||
" tab4 = realloc(tab4,21 * sizeof(int));\n"
|
" tab4 = realloc(tab4,21 * sizeof(int));\n"
|
||||||
" tab4[20] = 0;\n"
|
" tab4[20] = 0;\n"
|
||||||
" free(tab4);\n"
|
" free(tab4);\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2744,7 +2744,7 @@ private:
|
||||||
"[test.cpp:3]: (warning) Suspicious pointer subtraction. Did you intend to write '->'?\n", errout.str());
|
"[test.cpp:3]: (warning) Suspicious pointer subtraction. Did you intend to write '->'?\n", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
void checkConst(const char code[], const Settings *s = 0, bool inconclusive = true, bool verify = true) {
|
void checkConst(const char code[], const Settings *s = 0, bool inconclusive = true) {
|
||||||
// Clear the error log
|
// Clear the error log
|
||||||
errout.str("");
|
errout.str("");
|
||||||
|
|
||||||
|
@ -2760,12 +2760,7 @@ private:
|
||||||
Tokenizer tokenizer(&settings, this);
|
Tokenizer tokenizer(&settings, this);
|
||||||
std::istringstream istr(code);
|
std::istringstream istr(code);
|
||||||
tokenizer.tokenize(istr, "test.cpp");
|
tokenizer.tokenize(istr, "test.cpp");
|
||||||
|
|
||||||
const std::string str1(tokenizer.tokens()->stringifyList(0,true));
|
|
||||||
tokenizer.simplifyTokenList2();
|
tokenizer.simplifyTokenList2();
|
||||||
const std::string str2(tokenizer.tokens()->stringifyList(0,true));
|
|
||||||
if (verify && str1 != str2)
|
|
||||||
warnUnsimplified(str1, str2);
|
|
||||||
|
|
||||||
CheckClass checkClass(&tokenizer, &settings, this);
|
CheckClass checkClass(&tokenizer, &settings, this);
|
||||||
checkClass.checkConst();
|
checkClass.checkConst();
|
||||||
|
@ -3962,8 +3957,7 @@ private:
|
||||||
" if( m_d != 0 )\n"
|
" if( m_d != 0 )\n"
|
||||||
" return m_iRealVal / m_d;\n"
|
" return m_iRealVal / m_d;\n"
|
||||||
" return dRet;\n"
|
" return dRet;\n"
|
||||||
"};", nullptr, true, false
|
"};", nullptr, true);
|
||||||
);
|
|
||||||
ASSERT_EQUALS("[test.cpp:9] -> [test.cpp:4]: (style, inconclusive) Technically the member function 'A::dGetValue' can be const.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:9] -> [test.cpp:4]: (style, inconclusive) Technically the member function 'A::dGetValue' can be const.\n", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -66,7 +66,7 @@ private:
|
||||||
TEST_CASE(alwaysTrue);
|
TEST_CASE(alwaysTrue);
|
||||||
}
|
}
|
||||||
|
|
||||||
void check(const char code[], bool validate=true, const char* filename = "test.cpp") {
|
void check(const char code[], const char* filename = "test.cpp") {
|
||||||
// Clear the error buffer..
|
// Clear the error buffer..
|
||||||
errout.str("");
|
errout.str("");
|
||||||
|
|
||||||
|
@ -81,15 +81,8 @@ private:
|
||||||
std::istringstream istr(code);
|
std::istringstream istr(code);
|
||||||
tokenizer.tokenize(istr, filename);
|
tokenizer.tokenize(istr, filename);
|
||||||
checkCondition.runChecks(&tokenizer, &settings, this);
|
checkCondition.runChecks(&tokenizer, &settings, this);
|
||||||
const std::string str1(tokenizer.tokens()->stringifyList(0,true));
|
|
||||||
tokenizer.simplifyTokenList2();
|
tokenizer.simplifyTokenList2();
|
||||||
const std::string str2(tokenizer.tokens()->stringifyList(0,true));
|
|
||||||
checkCondition.runSimplifiedChecks(&tokenizer, &settings, this);
|
checkCondition.runSimplifiedChecks(&tokenizer, &settings, this);
|
||||||
|
|
||||||
// Ensure that the test case is not bad.
|
|
||||||
if (validate && str1 != str2) {
|
|
||||||
warnUnsimplified(str1, str2);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void assignAndCompare() {
|
void assignAndCompare() {
|
||||||
|
@ -380,15 +373,8 @@ private:
|
||||||
|
|
||||||
CheckCondition checkCondition;
|
CheckCondition checkCondition;
|
||||||
checkCondition.runChecks(&tokenizer, &settings, this);
|
checkCondition.runChecks(&tokenizer, &settings, this);
|
||||||
const std::string str1(tokenizer.tokens()->stringifyList(0,true));
|
|
||||||
tokenizer.simplifyTokenList2();
|
tokenizer.simplifyTokenList2();
|
||||||
const std::string str2(tokenizer.tokens()->stringifyList(0,true));
|
|
||||||
checkCondition.runSimplifiedChecks(&tokenizer, &settings, this);
|
checkCondition.runSimplifiedChecks(&tokenizer, &settings, this);
|
||||||
|
|
||||||
// Ensure that the test case is not bad.
|
|
||||||
if (str1 != str2) {
|
|
||||||
warnUnsimplified(str1, str2);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
void duplicateIf() {
|
void duplicateIf() {
|
||||||
check("void f(int a, int &b) {\n"
|
check("void f(int a, int &b) {\n"
|
||||||
|
@ -468,19 +454,19 @@ private:
|
||||||
check("void f(WIDGET *widget) {\n"
|
check("void f(WIDGET *widget) {\n"
|
||||||
" if (dynamic_cast<BUTTON*>(widget)){}\n"
|
" if (dynamic_cast<BUTTON*>(widget)){}\n"
|
||||||
" else if (dynamic_cast<LABEL*>(widget)){}\n"
|
" else if (dynamic_cast<LABEL*>(widget)){}\n"
|
||||||
"}",false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void f(int x) {\n" // #6482
|
check("void f(int x) {\n" // #6482
|
||||||
" if (x & 1) {}\n"
|
" if (x & 1) {}\n"
|
||||||
" else if (x == 0) {}\n"
|
" else if (x == 0) {}\n"
|
||||||
"}",false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void f(int x) {\n"
|
check("void f(int x) {\n"
|
||||||
" if (x & 15) {}\n"
|
" if (x & 15) {}\n"
|
||||||
" else if (x == 40) {}\n"
|
" else if (x == 40) {}\n"
|
||||||
"}",false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:3]: (style) Expression is always false because 'else if' condition matches previous condition at line 2.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3]: (style) Expression is always false because 'else if' condition matches previous condition at line 2.\n", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -899,7 +885,7 @@ private:
|
||||||
void incorrectLogicOperator4() {
|
void incorrectLogicOperator4() {
|
||||||
check("void f(int x) {\n"
|
check("void f(int x) {\n"
|
||||||
" if (x && x != $0) {}\n"
|
" if (x && x != $0) {}\n"
|
||||||
"}", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1329,7 +1315,7 @@ private:
|
||||||
void clarifyCondition1() {
|
void clarifyCondition1() {
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
" if (x = b() < 0) {}\n" // don't simplify and verify this code
|
" if (x = b() < 0) {}\n" // don't simplify and verify this code
|
||||||
"}", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:2]: (style) Suspicious condition (assignment + comparison); Clarify expression with parentheses.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:2]: (style) Suspicious condition (assignment + comparison); Clarify expression with parentheses.\n", errout.str());
|
||||||
|
|
||||||
check("void f(int i) {\n"
|
check("void f(int i) {\n"
|
||||||
|
@ -1344,61 +1330,61 @@ private:
|
||||||
|
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
" if (x = b < 0 ? 1 : 2) {}\n" // don't simplify and verify this code
|
" if (x = b < 0 ? 1 : 2) {}\n" // don't simplify and verify this code
|
||||||
"}", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
" int y = rand(), z = rand();\n"
|
" int y = rand(), z = rand();\n"
|
||||||
" if (y || (!y && z));\n"
|
" if (y || (!y && z));\n"
|
||||||
"}", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:3]: (style) Redundant condition: !y. 'A && (!A || B)' is equivalent to 'A || B'\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3]: (style) Redundant condition: !y. 'A && (!A || B)' is equivalent to 'A || B'\n", errout.str());
|
||||||
|
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
" int y = rand(), z = rand();\n"
|
" int y = rand(), z = rand();\n"
|
||||||
" if (y || !y && z);\n"
|
" if (y || !y && z);\n"
|
||||||
"}", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:3]: (style) Redundant condition: !y. 'A && (!A || B)' is equivalent to 'A || B'\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3]: (style) Redundant condition: !y. 'A && (!A || B)' is equivalent to 'A || B'\n", errout.str());
|
||||||
|
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
" if (!a || a && b) {}\n"
|
" if (!a || a && b) {}\n"
|
||||||
"}", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:2]: (style) Redundant condition: a. 'A && (!A || B)' is equivalent to 'A || B'\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:2]: (style) Redundant condition: a. 'A && (!A || B)' is equivalent to 'A || B'\n", errout.str());
|
||||||
|
|
||||||
|
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
" if (!tok->next()->function() || \n"
|
" if (!tok->next()->function() || \n"
|
||||||
" (tok->next()->function() && tok->next()->function()->isConstructor()));\n"
|
" (tok->next()->function() && tok->next()->function()->isConstructor()));\n"
|
||||||
"}", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:2]: (style) Redundant condition: tok.next().function(). 'A && (!A || B)' is equivalent to 'A || B'\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:2]: (style) Redundant condition: tok.next().function(). 'A && (!A || B)' is equivalent to 'A || B'\n", errout.str());
|
||||||
|
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
" if (!tok->next()->function() || \n"
|
" if (!tok->next()->function() || \n"
|
||||||
" (!tok->next()->function() && tok->next()->function()->isConstructor()));\n"
|
" (!tok->next()->function() && tok->next()->function()->isConstructor()));\n"
|
||||||
"}", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
" if (!tok->next()->function() || \n"
|
" if (!tok->next()->function() || \n"
|
||||||
" (!tok2->next()->function() && tok->next()->function()->isConstructor()));\n"
|
" (!tok2->next()->function() && tok->next()->function()->isConstructor()));\n"
|
||||||
"}", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
" if (!tok->next(1)->function(1) || \n"
|
" if (!tok->next(1)->function(1) || \n"
|
||||||
" (tok->next(1)->function(1) && tok->next(1)->function(1)->isConstructor()));\n"
|
" (tok->next(1)->function(1) && tok->next(1)->function(1)->isConstructor()));\n"
|
||||||
"}", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:2]: (style) Redundant condition: tok.next(1).function(1). 'A && (!A || B)' is equivalent to 'A || B'\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:2]: (style) Redundant condition: tok.next(1).function(1). 'A && (!A || B)' is equivalent to 'A || B'\n", errout.str());
|
||||||
|
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
" if (!tok->next()->function(1) || \n"
|
" if (!tok->next()->function(1) || \n"
|
||||||
" (tok->next()->function(2) && tok->next()->function()->isConstructor()));\n"
|
" (tok->next()->function(2) && tok->next()->function()->isConstructor()));\n"
|
||||||
"}", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
" int y = rand(), z = rand();\n"
|
" int y = rand(), z = rand();\n"
|
||||||
" if (y==0 || y!=0 && z);\n"
|
" if (y==0 || y!=0 && z);\n"
|
||||||
"}", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:3]: (style) Redundant condition: y!=0. 'A && (!A || B)' is equivalent to 'A || B'\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3]: (style) Redundant condition: y!=0. 'A && (!A || B)' is equivalent to 'A || B'\n", errout.str());
|
||||||
|
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
|
@ -1438,15 +1424,15 @@ private:
|
||||||
check("void f() { A<x &> a; }");
|
check("void f() { A<x &> a; }");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void f() { a(x<y|z,0); }", true, "test.c"); // filename is c => there are never templates
|
check("void f() { a(x<y|z,0); }", "test.c"); // filename is c => there are never templates
|
||||||
ASSERT_EQUALS("[test.c:1]: (style) Boolean result is used in bitwise operation. Clarify expression with parentheses.\n", errout.str());
|
ASSERT_EQUALS("[test.c:1]: (style) Boolean result is used in bitwise operation. Clarify expression with parentheses.\n", errout.str());
|
||||||
|
|
||||||
check("class A<B&,C>;", true, "test.cpp");
|
check("class A<B&,C>;", "test.cpp");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
" if (result != (char *)&inline_result) { }\n" // don't simplify and verify cast
|
" if (result != (char *)&inline_result) { }\n" // don't simplify and verify cast
|
||||||
"}", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -94,7 +94,7 @@ private:
|
||||||
TEST_CASE(nullpointer_internal_error); // #5080
|
TEST_CASE(nullpointer_internal_error); // #5080
|
||||||
}
|
}
|
||||||
|
|
||||||
void check(const char code[], bool inconclusive = false, const char filename[] = "test.cpp", bool verify=true) {
|
void check(const char code[], bool inconclusive = false, const char filename[] = "test.cpp") {
|
||||||
// Clear the error buffer..
|
// Clear the error buffer..
|
||||||
errout.str("");
|
errout.str("");
|
||||||
|
|
||||||
|
@ -111,11 +111,7 @@ private:
|
||||||
CheckNullPointer checkNullPointer(&tokenizer, &settings, this);
|
CheckNullPointer checkNullPointer(&tokenizer, &settings, this);
|
||||||
checkNullPointer.nullPointer();
|
checkNullPointer.nullPointer();
|
||||||
|
|
||||||
const std::string str1(tokenizer.tokens()->stringifyList(0,true));
|
|
||||||
tokenizer.simplifyTokenList2();
|
tokenizer.simplifyTokenList2();
|
||||||
const std::string str2(tokenizer.tokens()->stringifyList(0,true));
|
|
||||||
if (verify && str1 != str2)
|
|
||||||
warnUnsimplified(str1, str2);
|
|
||||||
|
|
||||||
checkNullPointer.nullConstantDereference();
|
checkNullPointer.nullConstantDereference();
|
||||||
}
|
}
|
||||||
|
@ -236,7 +232,7 @@ private:
|
||||||
" }\n"
|
" }\n"
|
||||||
" else if (a->x == 2) { }\n"
|
" else if (a->x == 2) { }\n"
|
||||||
" if (a) { }\n"
|
" if (a) { }\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// ticket #2134 - sizeof doesn't dereference
|
// ticket #2134 - sizeof doesn't dereference
|
||||||
|
@ -246,7 +242,7 @@ private:
|
||||||
" sizeof(*list);\n"
|
" sizeof(*list);\n"
|
||||||
" if (!list)\n"
|
" if (!list)\n"
|
||||||
" ;\n"
|
" ;\n"
|
||||||
"}", true, "test.cpp", false);
|
"}", true);
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// ticket #2245 - sizeof doesn't dereference
|
// ticket #2245 - sizeof doesn't dereference
|
||||||
|
@ -307,7 +303,7 @@ private:
|
||||||
" return;\n"
|
" return;\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
" if (!abc);\n"
|
" if (!abc);\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:2] -> [test.cpp:5]: (warning) Possible null pointer dereference: abc - otherwise it is redundant to check it against null.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:2] -> [test.cpp:5]: (warning) Possible null pointer dereference: abc - otherwise it is redundant to check it against null.\n", errout.str());
|
||||||
|
|
||||||
// TODO: False negative if member of member is dereferenced
|
// TODO: False negative if member of member is dereferenced
|
||||||
|
@ -322,7 +318,7 @@ private:
|
||||||
" abc->a = 0;\n"
|
" abc->a = 0;\n"
|
||||||
" if (abc && abc->b == 0)\n"
|
" if (abc && abc->b == 0)\n"
|
||||||
" ;\n"
|
" ;\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:2] -> [test.cpp:3]: (warning) Possible null pointer dereference: abc - otherwise it is redundant to check it against null.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:2] -> [test.cpp:3]: (warning) Possible null pointer dereference: abc - otherwise it is redundant to check it against null.\n", errout.str());
|
||||||
|
|
||||||
// ok dereferencing in a condition
|
// ok dereferencing in a condition
|
||||||
|
@ -352,7 +348,7 @@ private:
|
||||||
check("void f(struct ABC *abc) {\n"
|
check("void f(struct ABC *abc) {\n"
|
||||||
" abc = (ABC *)(abc->_next);\n"
|
" abc = (ABC *)(abc->_next);\n"
|
||||||
" if (abc) { }"
|
" if (abc) { }"
|
||||||
"}", true, "test.cpp", false);
|
"}", true);
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// reassign struct..
|
// reassign struct..
|
||||||
|
@ -385,7 +381,7 @@ private:
|
||||||
"out:\n"
|
"out:\n"
|
||||||
" if (!abc)\n"
|
" if (!abc)\n"
|
||||||
" ;\n"
|
" ;\n"
|
||||||
"}",false,"test.cpp",false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// loops..
|
// loops..
|
||||||
|
@ -420,7 +416,7 @@ private:
|
||||||
" int a = abc->a;\n"
|
" int a = abc->a;\n"
|
||||||
" if (!dynamic_cast<DEF *>(abc))\n"
|
" if (!dynamic_cast<DEF *>(abc))\n"
|
||||||
" ;\n"
|
" ;\n"
|
||||||
"}",false,"test.cpp",false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// #2641 - global pointer, function call
|
// #2641 - global pointer, function call
|
||||||
|
@ -559,7 +555,7 @@ private:
|
||||||
"{\n"
|
"{\n"
|
||||||
" if (*p == 0) { }\n"
|
" if (*p == 0) { }\n"
|
||||||
" if (!p) { }\n"
|
" if (!p) { }\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:4]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:4]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n", errout.str());
|
||||||
|
|
||||||
// no error
|
// no error
|
||||||
|
@ -596,7 +592,7 @@ private:
|
||||||
" int a = 2 * x;"
|
" int a = 2 * x;"
|
||||||
" if (x == 0)\n"
|
" if (x == 0)\n"
|
||||||
" ;\n"
|
" ;\n"
|
||||||
"}", true, "test.cpp", false);
|
"}", true);
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void foo(int *p)\n"
|
check("void foo(int *p)\n"
|
||||||
|
@ -649,7 +645,7 @@ private:
|
||||||
" int * a=0;\n"
|
" int * a=0;\n"
|
||||||
" if (!a) {};\n"
|
" if (!a) {};\n"
|
||||||
" int c = a ? 0 : 1;\n"
|
" int c = a ? 0 : 1;\n"
|
||||||
"}\n",true,"test.cpp",false);
|
"}\n",true);
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// #3686
|
// #3686
|
||||||
|
@ -657,14 +653,14 @@ private:
|
||||||
" int * a=0;\n"
|
" int * a=0;\n"
|
||||||
" if (!a) {};\n"
|
" if (!a) {};\n"
|
||||||
" int c = a ? b : b+1;\n"
|
" int c = a ? b : b+1;\n"
|
||||||
"}\n",true,"test.cpp",false);
|
"}\n",true);
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
" int * a=0;\n"
|
" int * a=0;\n"
|
||||||
" if (!a) {};\n"
|
" if (!a) {};\n"
|
||||||
" int c = (a) ? b : b+1;\n"
|
" int c = (a) ? b : b+1;\n"
|
||||||
"}\n",true,"test.cpp",false);
|
"}\n",true);
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void foo(P *p)\n"
|
check("void foo(P *p)\n"
|
||||||
|
@ -808,26 +804,26 @@ private:
|
||||||
" int c = sizeof(test[0]);\n"
|
" int c = sizeof(test[0]);\n"
|
||||||
" if (!test)\n"
|
" if (!test)\n"
|
||||||
" ;\n"
|
" ;\n"
|
||||||
"}", true, "test.cpp", false);
|
"}", true);
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void f(type* p) {\n" // #4983
|
check("void f(type* p) {\n" // #4983
|
||||||
" x(sizeof p[0]);\n"
|
" x(sizeof p[0]);\n"
|
||||||
" if (!p)\n"
|
" if (!p)\n"
|
||||||
" ;\n"
|
" ;\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// #3023 - checked deref
|
// #3023 - checked deref
|
||||||
check("void f(struct ABC *abc) {\n"
|
check("void f(struct ABC *abc) {\n"
|
||||||
" WARN_ON(!abc || abc->x == 0);\n"
|
" WARN_ON(!abc || abc->x == 0);\n"
|
||||||
" if (!abc) { }\n"
|
" if (!abc) { }\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
check("void f(struct ABC *abc) {\n"
|
check("void f(struct ABC *abc) {\n"
|
||||||
" WARN_ON(!abc || abc->x == 7);\n"
|
" WARN_ON(!abc || abc->x == 7);\n"
|
||||||
" if (!abc) { }\n"
|
" if (!abc) { }\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// #3425 - false positives when there are macros
|
// #3425 - false positives when there are macros
|
||||||
|
@ -1116,7 +1112,7 @@ private:
|
||||||
"{\n"
|
"{\n"
|
||||||
" std::string * x = 0;\n"
|
" std::string * x = 0;\n"
|
||||||
" *x = \"test\";\n"
|
" *x = \"test\";\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:4]: (error) Possible null pointer dereference: x\n"
|
ASSERT_EQUALS("[test.cpp:4]: (error) Possible null pointer dereference: x\n"
|
||||||
"[test.cpp:4]: (error) Null pointer dereference\n", errout.str());
|
"[test.cpp:4]: (error) Null pointer dereference\n", errout.str());
|
||||||
}
|
}
|
||||||
|
@ -1147,11 +1143,11 @@ private:
|
||||||
" return *i;\n"
|
" return *i;\n"
|
||||||
"}\n";
|
"}\n";
|
||||||
|
|
||||||
check(code, false, "test.cpp", false); // C++ file => nullptr means NULL
|
check(code, false, "test.cpp"); // C++ file => nullptr means NULL
|
||||||
ASSERT_EQUALS("[test.cpp:4]: (error) Possible null pointer dereference: i\n"
|
ASSERT_EQUALS("[test.cpp:4]: (error) Possible null pointer dereference: i\n"
|
||||||
"[test.cpp:4]: (error) Null pointer dereference\n", errout.str());
|
"[test.cpp:4]: (error) Null pointer dereference\n", errout.str());
|
||||||
|
|
||||||
check(code, false, "test.c", false); // C file => nullptr does not mean NULL
|
check(code, false, "test.c"); // C file => nullptr does not mean NULL
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1198,7 +1194,7 @@ private:
|
||||||
" {\n"
|
" {\n"
|
||||||
" i++;\n"
|
" i++;\n"
|
||||||
" };\n"
|
" };\n"
|
||||||
"}\n", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:5]: (error) Possible null pointer dereference: str\n"
|
ASSERT_EQUALS("[test.cpp:5]: (error) Possible null pointer dereference: str\n"
|
||||||
"[test.cpp:5]: (error) Null pointer dereference\n", errout.str());
|
"[test.cpp:5]: (error) Null pointer dereference\n", errout.str());
|
||||||
}
|
}
|
||||||
|
@ -1291,7 +1287,7 @@ private:
|
||||||
" pointer_=NULL;\n"
|
" pointer_=NULL;\n"
|
||||||
" *pointer_=0;\n"
|
" *pointer_=0;\n"
|
||||||
" return *this;\n"
|
" return *this;\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:8]: (error) Possible null pointer dereference: pointer_\n"
|
ASSERT_EQUALS("[test.cpp:8]: (error) Possible null pointer dereference: pointer_\n"
|
||||||
"[test.cpp:8]: (error) Null pointer dereference\n", errout.str());
|
"[test.cpp:8]: (error) Null pointer dereference\n", errout.str());
|
||||||
}
|
}
|
||||||
|
@ -1321,7 +1317,7 @@ private:
|
||||||
" break;\n"
|
" break;\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
" return p;\n"
|
" return p;\n"
|
||||||
"}", true, "test.cpp", false);
|
"}", true);
|
||||||
ASSERT_EQUALS("[test.cpp:7]: (error) Possible null pointer dereference: p\n"
|
ASSERT_EQUALS("[test.cpp:7]: (error) Possible null pointer dereference: p\n"
|
||||||
"[test.cpp:7]: (error) Null pointer dereference\n", errout.str());
|
"[test.cpp:7]: (error) Null pointer dereference\n", errout.str());
|
||||||
}
|
}
|
||||||
|
@ -1357,34 +1353,34 @@ private:
|
||||||
" if (NULL == p) {\n"
|
" if (NULL == p) {\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
" *p = 0;\n"
|
" *p = 0;\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:4] -> [test.cpp:2]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:4] -> [test.cpp:2]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n", errout.str());
|
||||||
|
|
||||||
check("void foo(char *p) {\n"
|
check("void foo(char *p) {\n"
|
||||||
" if (p == NULL) {\n"
|
" if (p == NULL) {\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
" *p = 0;\n"
|
" *p = 0;\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:4] -> [test.cpp:2]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:4] -> [test.cpp:2]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n", errout.str());
|
||||||
|
|
||||||
check("void foo(char *p) {\n"
|
check("void foo(char *p) {\n"
|
||||||
" if (p == NULL) {\n"
|
" if (p == NULL) {\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
" printf(\"%c\", *p);\n"
|
" printf(\"%c\", *p);\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:4] -> [test.cpp:2]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:4] -> [test.cpp:2]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n", errout.str());
|
||||||
|
|
||||||
check("void foo(char *p) {\n"
|
check("void foo(char *p) {\n"
|
||||||
" if (p && *p == 0) {\n"
|
" if (p && *p == 0) {\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
" printf(\"%c\", *p);\n"
|
" printf(\"%c\", *p);\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:4] -> [test.cpp:2]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:4] -> [test.cpp:2]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n", errout.str());
|
||||||
|
|
||||||
check("void foo(char *p) {\n"
|
check("void foo(char *p) {\n"
|
||||||
" if (p && *p == 0) {\n"
|
" if (p && *p == 0) {\n"
|
||||||
" } else { *p = 0; }\n"
|
" } else { *p = 0; }\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:2]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:2]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n", errout.str());
|
||||||
|
|
||||||
check("void foo(char *p) {\n"
|
check("void foo(char *p) {\n"
|
||||||
|
@ -1486,7 +1482,7 @@ private:
|
||||||
" if (!dynamic_cast<bar *>(foo)) {\n"
|
" if (!dynamic_cast<bar *>(foo)) {\n"
|
||||||
" *foo = 0;\n"
|
" *foo = 0;\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// ticket: #2300 - calling unknown function that may initialize the pointer
|
// ticket: #2300 - calling unknown function that may initialize the pointer
|
||||||
|
@ -1514,7 +1510,7 @@ private:
|
||||||
" MACRO;\n"
|
" MACRO;\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
" fred->a();\n"
|
" fred->a();\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// #2493 - switch
|
// #2493 - switch
|
||||||
|
@ -1527,7 +1523,7 @@ private:
|
||||||
" fred->a();\n"
|
" fred->a();\n"
|
||||||
" break;\n"
|
" break;\n"
|
||||||
" };\n"
|
" };\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// #4118 - second if
|
// #4118 - second if
|
||||||
|
@ -1563,7 +1559,7 @@ private:
|
||||||
" else {\n"
|
" else {\n"
|
||||||
" int b = *i;\n"
|
" int b = *i;\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
"}", true, "test.cpp", false);
|
"}", true);
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// #2696 - false positives nr 1
|
// #2696 - false positives nr 1
|
||||||
|
@ -1576,7 +1572,7 @@ private:
|
||||||
"\n"
|
"\n"
|
||||||
" if (pFoo)\n"
|
" if (pFoo)\n"
|
||||||
" bar();\n"
|
" bar();\n"
|
||||||
"}", true, "test.cpp", false);
|
"}", true);
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// #2696 - false positives nr 2
|
// #2696 - false positives nr 2
|
||||||
|
@ -1625,7 +1621,7 @@ private:
|
||||||
" if (p == 0 && (p = malloc(10)) != 0) {\n"
|
" if (p == 0 && (p = malloc(10)) != 0) {\n"
|
||||||
" *p = 0;\n"
|
" *p = 0;\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// check, assign and use
|
// check, assign and use
|
||||||
|
@ -1634,7 +1630,7 @@ private:
|
||||||
" if (p == 0 && (p = malloc(10)) != a && (*p = a)) {\n"
|
" if (p == 0 && (p = malloc(10)) != a && (*p = a)) {\n"
|
||||||
" *p = 0;\n"
|
" *p = 0;\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// check, and use
|
// check, and use
|
||||||
|
@ -1643,7 +1639,7 @@ private:
|
||||||
" if (p == 0 && (*p = 0)) {\n"
|
" if (p == 0 && (*p = 0)) {\n"
|
||||||
" return;\n"
|
" return;\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:3]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:3]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n", errout.str());
|
||||||
|
|
||||||
// check, and use
|
// check, and use
|
||||||
|
@ -1652,7 +1648,7 @@ private:
|
||||||
" if (p == 0 && p->x == 10) {\n"
|
" if (p == 0 && p->x == 10) {\n"
|
||||||
" return;\n"
|
" return;\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:3]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:3]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n", errout.str());
|
||||||
|
|
||||||
// check, and use
|
// check, and use
|
||||||
|
@ -1661,7 +1657,7 @@ private:
|
||||||
" if (p == 0 || p->x == 10) {\n"
|
" if (p == 0 || p->x == 10) {\n"
|
||||||
" return;\n"
|
" return;\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// check, and use
|
// check, and use
|
||||||
|
@ -1670,7 +1666,7 @@ private:
|
||||||
" if (p == NULL && (*p = a)) {\n"
|
" if (p == NULL && (*p = a)) {\n"
|
||||||
" return;\n"
|
" return;\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:3]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:3]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n", errout.str());
|
||||||
|
|
||||||
// check, and use
|
// check, and use
|
||||||
|
@ -1678,7 +1674,7 @@ private:
|
||||||
" if (!p && x==1 || p && p->x==0) {\n"
|
" if (!p && x==1 || p && p->x==0) {\n"
|
||||||
" return;\n"
|
" return;\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
{
|
{
|
||||||
|
@ -1687,17 +1683,17 @@ private:
|
||||||
" fred->x();\n"
|
" fred->x();\n"
|
||||||
"}";
|
"}";
|
||||||
|
|
||||||
check(code, false, "test.cpp", false); // non-inconclusive
|
check(code, false); // non-inconclusive
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check(code, true, "test.cpp", false); // inconclusive
|
check(code, true); // inconclusive
|
||||||
ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:2]: (warning, inconclusive) Possible null pointer dereference: fred - otherwise it is redundant to check it against null.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:2]: (warning, inconclusive) Possible null pointer dereference: fred - otherwise it is redundant to check it against null.\n", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
check("void f(char *s) {\n" // #3358
|
check("void f(char *s) {\n" // #3358
|
||||||
" if (s==0);\n"
|
" if (s==0);\n"
|
||||||
" strcpy(a, s?b:c);\n"
|
" strcpy(a, s?b:c);\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// sizeof
|
// sizeof
|
||||||
|
@ -1742,7 +1738,7 @@ private:
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
" int *pointer = NULL;\n"
|
" int *pointer = NULL;\n"
|
||||||
" pointer = func(sizeof pointer[0]);\n"
|
" pointer = func(sizeof pointer[0]);\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1751,7 +1747,7 @@ private:
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
" int* p = 0;\n"
|
" int* p = 0;\n"
|
||||||
" return p[4];\n"
|
" return p[4];\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:3]: (error) Possible null pointer dereference: p\n"
|
ASSERT_EQUALS("[test.cpp:3]: (error) Possible null pointer dereference: p\n"
|
||||||
"[test.cpp:3]: (error) Null pointer dereference\n", errout.str());
|
"[test.cpp:3]: (error) Null pointer dereference\n", errout.str());
|
||||||
|
|
||||||
|
@ -1805,7 +1801,7 @@ private:
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
" char *s = 0;\n"
|
" char *s = 0;\n"
|
||||||
" printf(\"%s\", s == 0 ? a : s);\n"
|
" printf(\"%s\", s == 0 ? a : s);\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
|
@ -1929,20 +1925,20 @@ private:
|
||||||
"bool foo() {\n"
|
"bool foo() {\n"
|
||||||
" PolymorphicA* a = 0;\n"
|
" PolymorphicA* a = 0;\n"
|
||||||
" return typeid(*a) == typeid(*a);\n"
|
" return typeid(*a) == typeid(*a);\n"
|
||||||
"}", true, "test.cpp", false);
|
"}", true);
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("struct NonPolymorphicA { ~A() {} };\n"
|
check("struct NonPolymorphicA { ~A() {} };\n"
|
||||||
"bool foo() {\n"
|
"bool foo() {\n"
|
||||||
" NonPolymorphicA* a = 0;\n"
|
" NonPolymorphicA* a = 0;\n"
|
||||||
" return typeid(*a) == typeid(*a);\n"
|
" return typeid(*a) == typeid(*a);\n"
|
||||||
"}", true, "test.cpp", false);
|
"}", true);
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("bool foo() {\n"
|
check("bool foo() {\n"
|
||||||
" char* c = 0;\n"
|
" char* c = 0;\n"
|
||||||
" return typeid(*c) == typeid(*c);\n"
|
" return typeid(*c) == typeid(*c);\n"
|
||||||
"}", true, "test.cpp", false);
|
"}", true);
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -2063,7 +2059,7 @@ private:
|
||||||
" oss << foo << p;\n"
|
" oss << foo << p;\n"
|
||||||
" if(q == 0)\n"
|
" if(q == 0)\n"
|
||||||
" oss << foo << q;\n"
|
" oss << foo << q;\n"
|
||||||
"}", false, "test.cpp", false);
|
"}", false);
|
||||||
ASSERT_EQUALS("[test.cpp:3]: (error) Possible null pointer dereference: p\n"
|
ASSERT_EQUALS("[test.cpp:3]: (error) Possible null pointer dereference: p\n"
|
||||||
"[test.cpp:4]: (error) Possible null pointer dereference: p\n"
|
"[test.cpp:4]: (error) Possible null pointer dereference: p\n"
|
||||||
"[test.cpp:6] -> [test.cpp:5]: (warning) Possible null pointer dereference: q - otherwise it is redundant to check it against null.\n", errout.str());
|
"[test.cpp:6] -> [test.cpp:5]: (warning) Possible null pointer dereference: q - otherwise it is redundant to check it against null.\n", errout.str());
|
||||||
|
@ -2075,7 +2071,7 @@ private:
|
||||||
" std::cin >> p;\n"
|
" std::cin >> p;\n"
|
||||||
" std::cout << abc << p;\n"
|
" std::cout << abc << p;\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
"}", false, "test.cpp", false);
|
"}", false);
|
||||||
TODO_ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:2]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n"
|
TODO_ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:2]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n"
|
||||||
"[test.cpp:4] -> [test.cpp:2]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n"
|
"[test.cpp:4] -> [test.cpp:2]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n"
|
||||||
"[test.cpp:5] -> [test.cpp:2]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n"
|
"[test.cpp:5] -> [test.cpp:2]: (warning) Possible null pointer dereference: p - otherwise it is redundant to check it against null.\n"
|
||||||
|
@ -2090,7 +2086,7 @@ private:
|
||||||
" char* p2 = 0;\n"
|
" char* p2 = 0;\n"
|
||||||
" std::cin >> (int)p;\n" // result casted
|
" std::cin >> (int)p;\n" // result casted
|
||||||
" std::cout << (int)p;\n"
|
" std::cout << (int)p;\n"
|
||||||
"}", true, "test.cpp", false);
|
"}", true);
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void f(const std::string& str) {\n"
|
check("void f(const std::string& str) {\n"
|
||||||
|
@ -2113,7 +2109,7 @@ private:
|
||||||
" stringstream out;\n"
|
" stringstream out;\n"
|
||||||
" out << ((ip >> 0) & 0xFF);\n"
|
" out << ((ip >> 0) & 0xFF);\n"
|
||||||
" return out.str();\n"
|
" return out.str();\n"
|
||||||
"}n", true, "test.cpp", false);
|
"}n", true);
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
// avoid regression from first fix attempt for #5811...
|
// avoid regression from first fix attempt for #5811...
|
||||||
check("void deserialize(const std::string &data) {\n"
|
check("void deserialize(const std::string &data) {\n"
|
||||||
|
@ -2121,7 +2117,7 @@ private:
|
||||||
"unsigned int len = 0;\n"
|
"unsigned int len = 0;\n"
|
||||||
"if (!(iss >> len))\n"
|
"if (!(iss >> len))\n"
|
||||||
" return;\n"
|
" return;\n"
|
||||||
"}\n", true, "test.cpp", false);
|
"}\n", true);
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -2322,7 +2318,7 @@ private:
|
||||||
check("void f(int *p = 0) {\n"
|
check("void f(int *p = 0) {\n"
|
||||||
" if (p != 0 && bar())\n"
|
" if (p != 0 && bar())\n"
|
||||||
" *p = 0;\n"
|
" *p = 0;\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void f(int *p) {\n"
|
check("void f(int *p) {\n"
|
||||||
|
@ -2333,7 +2329,7 @@ private:
|
||||||
check("void f(int *p = 0) {\n"
|
check("void f(int *p = 0) {\n"
|
||||||
" if (p != 0)\n"
|
" if (p != 0)\n"
|
||||||
" *p = 0;\n"
|
" *p = 0;\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void f(int *p = 0) {\n"
|
check("void f(int *p = 0) {\n"
|
||||||
|
@ -2341,19 +2337,19 @@ private:
|
||||||
" if (p == 0)\n"
|
" if (p == 0)\n"
|
||||||
" p = &y;\n"
|
" p = &y;\n"
|
||||||
" *p = 0;\n"
|
" *p = 0;\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void f(int *p = 0) {\n"
|
check("void f(int *p = 0) {\n"
|
||||||
" if (a != 0)\n"
|
" if (a != 0)\n"
|
||||||
" *p = 0;\n"
|
" *p = 0;\n"
|
||||||
"}", true, "test.cpp", false);
|
"}", true);
|
||||||
TODO_ASSERT_EQUALS("[test.cpp:3]: (warning) Possible null pointer dereference if the default parameter value is used: p\n", "", errout.str());
|
TODO_ASSERT_EQUALS("[test.cpp:3]: (warning) Possible null pointer dereference if the default parameter value is used: p\n", "", errout.str());
|
||||||
|
|
||||||
check("void f(int *p = 0) {\n"
|
check("void f(int *p = 0) {\n"
|
||||||
" p = a;\n"
|
" p = a;\n"
|
||||||
" *p = 0;\n" // <- don't simplify and verify
|
" *p = 0;\n" // <- don't simplify and verify
|
||||||
"}",false,"test.cpp",false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void f(int *p = 0) {\n"
|
check("void f(int *p = 0) {\n"
|
||||||
|
@ -2367,7 +2363,7 @@ private:
|
||||||
" return 0;\n"
|
" return 0;\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
" return *p;\n"
|
" return *p;\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void f(int *p = 0) {\n"
|
check("void f(int *p = 0) {\n"
|
||||||
|
@ -2441,7 +2437,7 @@ private:
|
||||||
" init(&p);\n"
|
" init(&p);\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
" *p = 0;\n"
|
" *p = 0;\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void f(int *p = 0) {\n"
|
check("void f(int *p = 0) {\n"
|
||||||
|
@ -2449,7 +2445,7 @@ private:
|
||||||
" throw SomeException;\n"
|
" throw SomeException;\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
" *p = 0;\n"
|
" *p = 0;\n"
|
||||||
"}", false, "test.cpp", false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void foo(int *p = 0) {\n"
|
check("void foo(int *p = 0) {\n"
|
||||||
|
|
|
@ -167,7 +167,7 @@ private:
|
||||||
TEST_CASE(test_isSameExpression);
|
TEST_CASE(test_isSameExpression);
|
||||||
}
|
}
|
||||||
|
|
||||||
void check(const char raw_code[], const char *filename = nullptr, bool experimental = false, bool inconclusive = true, bool runSimpleChecks=true, Settings* settings = 0, bool verify = true) {
|
void check(const char raw_code[], const char *filename = nullptr, bool experimental = false, bool inconclusive = true, bool runSimpleChecks=true, Settings* settings = 0) {
|
||||||
// Clear the error buffer..
|
// Clear the error buffer..
|
||||||
errout.str("");
|
errout.str("");
|
||||||
|
|
||||||
|
@ -200,11 +200,7 @@ private:
|
||||||
checkOther.runChecks(&tokenizer, settings, this);
|
checkOther.runChecks(&tokenizer, settings, this);
|
||||||
|
|
||||||
if (runSimpleChecks) {
|
if (runSimpleChecks) {
|
||||||
const std::string str1(tokenizer.tokens()->stringifyList(0,true));
|
|
||||||
tokenizer.simplifyTokenList2();
|
tokenizer.simplifyTokenList2();
|
||||||
const std::string str2(tokenizer.tokens()->stringifyList(0,true));
|
|
||||||
if (verify && str1 != str2)
|
|
||||||
warnUnsimplified(str1, str2);
|
|
||||||
checkOther.runSimplifiedChecks(&tokenizer, settings, this);
|
checkOther.runSimplifiedChecks(&tokenizer, settings, this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -415,13 +411,13 @@ private:
|
||||||
check("void f(int x) {\n"
|
check("void f(int x) {\n"
|
||||||
" int y = 17 / x;\n"
|
" int y = 17 / x;\n"
|
||||||
" if (x == 0) {}\n"
|
" if (x == 0) {}\n"
|
||||||
"}", nullptr, false, true, true, nullptr, false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:2]: (warning) Either the condition 'x==0' is useless or there is division by zero at line 2.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:2]: (warning) Either the condition 'x==0' is useless or there is division by zero at line 2.\n", errout.str());
|
||||||
|
|
||||||
check("void f(unsigned int x) {\n"
|
check("void f(unsigned int x) {\n"
|
||||||
" int y = 17 / x;\n"
|
" int y = 17 / x;\n"
|
||||||
" if (x != 0) {}\n"
|
" if (x != 0) {}\n"
|
||||||
"}", nullptr, false, true, true, nullptr, false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:2]: (warning) Either the condition 'x!=0' is useless or there is division by zero at line 2.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:2]: (warning) Either the condition 'x!=0' is useless or there is division by zero at line 2.\n", errout.str());
|
||||||
|
|
||||||
// function call
|
// function call
|
||||||
|
@ -438,7 +434,7 @@ private:
|
||||||
" int y = 17 / x;\n"
|
" int y = 17 / x;\n"
|
||||||
" x = some+calculation;\n"
|
" x = some+calculation;\n"
|
||||||
" if (x != 0) {}\n"
|
" if (x != 0) {}\n"
|
||||||
"}", nullptr, false, true, true, nullptr, false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
{
|
{
|
||||||
|
@ -449,7 +445,7 @@ private:
|
||||||
" int y = 17 / x;\n"
|
" int y = 17 / x;\n"
|
||||||
" do_something();\n"
|
" do_something();\n"
|
||||||
" if (x != 0) {}\n"
|
" if (x != 0) {}\n"
|
||||||
"}", nullptr, false, true, true, nullptr, false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// function is called. but don't care, variable is local
|
// function is called. but don't care, variable is local
|
||||||
|
@ -459,7 +455,7 @@ private:
|
||||||
" int y = 17 / x;\n"
|
" int y = 17 / x;\n"
|
||||||
" do_something();\n"
|
" do_something();\n"
|
||||||
" if (x != 0) {}\n"
|
" if (x != 0) {}\n"
|
||||||
"}", nullptr, false, true, true, nullptr, false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:6] -> [test.cpp:4]: (warning) Either the condition 'x!=0' is useless or there is division by zero at line 4.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:6] -> [test.cpp:4]: (warning) Either the condition 'x!=0' is useless or there is division by zero at line 4.\n", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -474,7 +470,7 @@ private:
|
||||||
"void f() {\n"
|
"void f() {\n"
|
||||||
" int y = 17 / x;\n"
|
" int y = 17 / x;\n"
|
||||||
" while (y || x == 0) { x--; }\n"
|
" while (y || x == 0) { x--; }\n"
|
||||||
"}", nullptr, false, true, true, nullptr, false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// ticket 5033 segmentation fault (valid code) in CheckOther::checkZeroDivisionOrUselessCondition
|
// ticket 5033 segmentation fault (valid code) in CheckOther::checkZeroDivisionOrUselessCondition
|
||||||
|
@ -497,19 +493,19 @@ private:
|
||||||
check("int f(int d) {\n"
|
check("int f(int d) {\n"
|
||||||
" int r = (a?b:c) / d;\n"
|
" int r = (a?b:c) / d;\n"
|
||||||
" if (d == 0) {}\n"
|
" if (d == 0) {}\n"
|
||||||
"}", nullptr, false, true, true, nullptr, false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:2]: (warning) Either the condition 'd==0' is useless or there is division by zero at line 2.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3] -> [test.cpp:2]: (warning) Either the condition 'd==0' is useless or there is division by zero at line 2.\n", errout.str());
|
||||||
|
|
||||||
check("int f(int a) {\n"
|
check("int f(int a) {\n"
|
||||||
" int r = a ? 1 / a : 0;\n"
|
" int r = a ? 1 / a : 0;\n"
|
||||||
" if (a == 0) {}\n"
|
" if (a == 0) {}\n"
|
||||||
"}", nullptr, false, true, true, nullptr, false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("int f(int a) {\n"
|
check("int f(int a) {\n"
|
||||||
" int r = (a == 0) ? 0 : 1 / a;\n"
|
" int r = (a == 0) ? 0 : 1 / a;\n"
|
||||||
" if (a == 0) {}\n"
|
" if (a == 0) {}\n"
|
||||||
"}", nullptr, false, true, true, nullptr, false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3220,7 +3216,7 @@ private:
|
||||||
" for (i == 0; i < 10; i ++) {\n"
|
" for (i == 0; i < 10; i ++) {\n"
|
||||||
" c ++;\n"
|
" c ++;\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
"}", nullptr, false, true, true, nullptr, false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:2]: (warning, inconclusive) Found suspicious equality comparison. Did you intend to assign a value instead?\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:2]: (warning, inconclusive) Found suspicious equality comparison. Did you intend to assign a value instead?\n", errout.str());
|
||||||
|
|
||||||
check("void foo(int c) {\n"
|
check("void foo(int c) {\n"
|
||||||
|
@ -3277,7 +3273,7 @@ private:
|
||||||
" for (int i = (x == 0) ? 0 : 5; i < 10; i ++) {\n"
|
" for (int i = (x == 0) ? 0 : 5; i < 10; i ++) {\n"
|
||||||
" x++;\n"
|
" x++;\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
"}", nullptr, false, true, true, nullptr, false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
check("void foo(int x) {\n"
|
check("void foo(int x) {\n"
|
||||||
|
@ -3359,7 +3355,7 @@ private:
|
||||||
check("void f(int x) {\n"
|
check("void f(int x) {\n"
|
||||||
" x = (x != 0);"
|
" x = (x != 0);"
|
||||||
" func(x);\n"
|
" func(x);\n"
|
||||||
"}", nullptr, false, true, true, nullptr, false);
|
"}");
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// ticket #3001 - false positive
|
// ticket #3001 - false positive
|
||||||
|
@ -3759,12 +3755,12 @@ private:
|
||||||
void clarifyCalculation() {
|
void clarifyCalculation() {
|
||||||
check("int f(char c) {\n"
|
check("int f(char c) {\n"
|
||||||
" return 10 * (c == 0) ? 1 : 2;\n"
|
" return 10 * (c == 0) ? 1 : 2;\n"
|
||||||
"}", nullptr, false, false, true, nullptr, false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:2]: (style) Clarify calculation precedence for '*' and '?'.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:2]: (style) Clarify calculation precedence for '*' and '?'.\n", errout.str());
|
||||||
|
|
||||||
check("void f(char c) {\n"
|
check("void f(char c) {\n"
|
||||||
" printf(\"%i\", 10 * (c == 0) ? 1 : 2);\n"
|
" printf(\"%i\", 10 * (c == 0) ? 1 : 2);\n"
|
||||||
"}", nullptr, false, false, true, nullptr, false);
|
"}");
|
||||||
ASSERT_EQUALS("[test.cpp:2]: (style) Clarify calculation precedence for '*' and '?'.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:2]: (style) Clarify calculation precedence for '*' and '?'.\n", errout.str());
|
||||||
|
|
||||||
check("void f() {\n"
|
check("void f() {\n"
|
||||||
|
@ -4297,7 +4293,7 @@ private:
|
||||||
|
|
||||||
check("void foo() {\n"
|
check("void foo() {\n"
|
||||||
" if ((mystrcmp(a, b) == 0) || (mystrcmp(a, b) == 0)) {}\n"
|
" if ((mystrcmp(a, b) == 0) || (mystrcmp(a, b) == 0)) {}\n"
|
||||||
"}", "test.cpp", false, false, true, &settings, false);
|
"}", "test.cpp", false, false, true, &settings);
|
||||||
ASSERT_EQUALS("[test.cpp:2] -> [test.cpp:2]: (style) Same expression on both sides of '||'.\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:2] -> [test.cpp:2]: (style) Same expression on both sides of '||'.\n", errout.str());
|
||||||
|
|
||||||
check("void GetValue() { return rand(); }\n"
|
check("void GetValue() { return rand(); }\n"
|
||||||
|
|
|
@ -245,18 +245,6 @@ void TestFixture::run(const std::string &str)
|
||||||
run();
|
run();
|
||||||
}
|
}
|
||||||
|
|
||||||
void TestFixture::warn(const char msg[]) const
|
|
||||||
{
|
|
||||||
warnings << "Warning: " << currentTest << " " << msg << std::endl;
|
|
||||||
}
|
|
||||||
|
|
||||||
void TestFixture::warnUnsimplified(const std::string& unsimplified, const std::string& simplified)
|
|
||||||
{
|
|
||||||
warn(("Unsimplified code in test case. It looks like this test "
|
|
||||||
"should either be cleaned up or moved to TestTokenizer or "
|
|
||||||
"TestSimplifyTokens instead.\nactual=" + unsimplified + "\nexpected=" + simplified).c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
void TestFixture::processOptions(const options& args)
|
void TestFixture::processOptions(const options& args)
|
||||||
{
|
{
|
||||||
quiet_tests = args.quiet();
|
quiet_tests = args.quiet();
|
||||||
|
|
|
@ -71,8 +71,6 @@ public:
|
||||||
virtual void reportOut(const std::string &outmsg);
|
virtual void reportOut(const std::string &outmsg);
|
||||||
virtual void reportErr(const ErrorLogger::ErrorMessage &msg);
|
virtual void reportErr(const ErrorLogger::ErrorMessage &msg);
|
||||||
void run(const std::string &str);
|
void run(const std::string &str);
|
||||||
void warn(const char msg[]) const;
|
|
||||||
void warnUnsimplified(const std::string& unsimplified, const std::string& simplified);
|
|
||||||
|
|
||||||
explicit TestFixture(const std::string &_name);
|
explicit TestFixture(const std::string &_name);
|
||||||
virtual ~TestFixture() { }
|
virtual ~TestFixture() { }
|
||||||
|
|
|
@ -75,7 +75,7 @@ private:
|
||||||
TEST_CASE(deadPointer);
|
TEST_CASE(deadPointer);
|
||||||
}
|
}
|
||||||
|
|
||||||
void checkUninitVar(const char code[], const char fname[] = "test.cpp", bool verify = true, bool debugwarnings = false) {
|
void checkUninitVar(const char code[], const char fname[] = "test.cpp", bool debugwarnings = false) {
|
||||||
// Clear the error buffer..
|
// Clear the error buffer..
|
||||||
errout.str("");
|
errout.str("");
|
||||||
|
|
||||||
|
@ -86,11 +86,7 @@ private:
|
||||||
std::istringstream istr(code);
|
std::istringstream istr(code);
|
||||||
tokenizer.tokenize(istr, fname);
|
tokenizer.tokenize(istr, fname);
|
||||||
|
|
||||||
const std::string str1(tokenizer.tokens()->stringifyList(0, true));
|
|
||||||
tokenizer.simplifyTokenList2();
|
tokenizer.simplifyTokenList2();
|
||||||
const std::string str2(tokenizer.tokens()->stringifyList(0, true));
|
|
||||||
if (verify && str1 != str2)
|
|
||||||
warnUnsimplified(str1, str2);
|
|
||||||
|
|
||||||
// Check for redundant code..
|
// Check for redundant code..
|
||||||
CheckUninitVar checkuninitvar(&tokenizer, &settings, this);
|
CheckUninitVar checkuninitvar(&tokenizer, &settings, this);
|
||||||
|
@ -3439,7 +3435,7 @@ private:
|
||||||
checkUninitVar("void f() {\n" // #4911 - bad simplification => don't crash
|
checkUninitVar("void f() {\n" // #4911 - bad simplification => don't crash
|
||||||
" int a;\n"
|
" int a;\n"
|
||||||
" do { a=do_something() } while (a);\n"
|
" do { a=do_something() } while (a);\n"
|
||||||
"}\n", "test.cpp", /*verify=*/true, /*debugwarnings=*/true);
|
"}\n", "test.cpp", /*debugwarnings=*/true);
|
||||||
ASSERT_EQUALS("[test.cpp:3]: (debug) ValueFlow bailout: variable a stopping on }\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:3]: (debug) ValueFlow bailout: variable a stopping on }\n", errout.str());
|
||||||
|
|
||||||
checkUninitVar("void f() {\n"
|
checkUninitVar("void f() {\n"
|
||||||
|
@ -3758,7 +3754,7 @@ private:
|
||||||
" struct flex_array *group;\n"
|
" struct flex_array *group;\n"
|
||||||
" struct cgroup_taskset tset = { };\n"
|
" struct cgroup_taskset tset = { };\n"
|
||||||
" do { } while_each_thread(leader, tsk);\n"
|
" do { } while_each_thread(leader, tsk);\n"
|
||||||
"}", "test.cpp", /*verify=*/true, /*debugwarnings=*/false);
|
"}", "test.cpp", /*debugwarnings=*/false);
|
||||||
ASSERT_EQUALS("", errout.str());
|
ASSERT_EQUALS("", errout.str());
|
||||||
|
|
||||||
// --debug-warnings mode => Debug warning
|
// --debug-warnings mode => Debug warning
|
||||||
|
@ -3768,7 +3764,7 @@ private:
|
||||||
" struct flex_array *group;\n"
|
" struct flex_array *group;\n"
|
||||||
" struct cgroup_taskset tset = { };\n"
|
" struct cgroup_taskset tset = { };\n"
|
||||||
" do { } while_each_thread(leader, tsk);\n"
|
" do { } while_each_thread(leader, tsk);\n"
|
||||||
"}", "test.cpp", /*verify=*/true, /*debugwarnings=*/true);
|
"}", "test.cpp", /*debugwarnings=*/true);
|
||||||
ASSERT_EQUALS("[test.cpp:6]: (debug) assertion failed '} while ('\n", errout.str());
|
ASSERT_EQUALS("[test.cpp:6]: (debug) assertion failed '} while ('\n", errout.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue