Fixed #6988 (incorrect nullPointer error for string)
This commit is contained in:
parent
8cee96a179
commit
1fd9ba0cc4
|
@ -446,14 +446,19 @@ void CheckNullPointer::nullConstantDereference()
|
|||
}
|
||||
|
||||
const Variable *ovar = nullptr;
|
||||
if (Token::Match(tok, "0 ==|!=|>|>=|<|<= %var% !!."))
|
||||
const Token *tokNull = nullptr;
|
||||
if (Token::Match(tok, "0 ==|!=|>|>=|<|<= %var%")) {
|
||||
if (!Token::Match(tok->tokAt(3),".|[")) {
|
||||
ovar = tok->tokAt(2)->variable();
|
||||
else if (Token::Match(tok, "%var% ==|!=|>|>=|<|<= 0"))
|
||||
tokNull = tok;
|
||||
}
|
||||
} else if (Token::Match(tok, "%var% ==|!=|>|>=|<|<= 0") ||
|
||||
Token::Match(tok, "%var% =|+ 0 )|]|,|;|+")) {
|
||||
ovar = tok->variable();
|
||||
else if (Token::Match(tok, "%var% =|+ 0 )|]|,|;|+"))
|
||||
ovar = tok->variable();
|
||||
if (ovar && !ovar->isPointer() && !ovar->isArray() && ovar->isStlStringType() && tok->tokAt(2)->originalName() != "'\\0'")
|
||||
nullPointerError(tok);
|
||||
tokNull = tok->tokAt(2);
|
||||
}
|
||||
if (ovar && !ovar->isPointer() && !ovar->isArray() && ovar->isStlStringType() && tokNull && tokNull->originalName() != "'\\0'")
|
||||
nullPointerError(tokNull);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -2030,6 +2030,36 @@ private:
|
|||
"[test.cpp:7]: (error) Possible null pointer dereference: p\n"
|
||||
"[test.cpp:8]: (error) Possible null pointer dereference: p\n", errout.str());
|
||||
|
||||
check("void f(std::string s1, const std::string& s2, const std::string* s3) {\n"
|
||||
" void* p = 0;\n"
|
||||
" if (x) { return; }\n"
|
||||
" foo(0 == s1.size());\n"
|
||||
" foo(0 == s2.size());\n"
|
||||
" foo(0 == s3->size());\n"
|
||||
" foo(s1.size() == 0);\n"
|
||||
" foo(s2.size() == 0);\n"
|
||||
" foo(s3->size() == 0);\n"
|
||||
"}", true);
|
||||
ASSERT_EQUALS("", errout.str());
|
||||
|
||||
check("void f(std::string s1, const std::string& s2) {\n"
|
||||
" if (x) { return; }\n"
|
||||
" foo(0 == s1[0]);\n"
|
||||
" foo(0 == s2[0]);\n"
|
||||
" foo(s1[0] == 0);\n"
|
||||
" foo(s2[0] == 0);\n"
|
||||
"}", true);
|
||||
ASSERT_EQUALS("", errout.str());
|
||||
|
||||
check("void f(std::string s1, const std::string& s2) {\n"
|
||||
" if (x) { return; }\n"
|
||||
" foo(s1 == '\\0');\n"
|
||||
" foo(s2 == '\\0');\n"
|
||||
" foo('\\0' == s1);\n"
|
||||
" foo('\\0' == s2);\n"
|
||||
"}", true);
|
||||
ASSERT_EQUALS("", errout.str());
|
||||
|
||||
check("class Bar {\n"
|
||||
" std::string s;\n"
|
||||
" Bar() : s(0) {}\n"
|
||||
|
|
Loading…
Reference in New Issue