diff --git a/lib/checkother.cpp b/lib/checkother.cpp index f976887e2..95585fa97 100644 --- a/lib/checkother.cpp +++ b/lib/checkother.cpp @@ -2454,17 +2454,22 @@ void CheckOther::nullPointerByDeRefAndChec() { if (Token::Match(tok1->tokAt(-2), "[=;{}] *")) { - nullPointerError(tok1, varname); + nullPointerError(tok1, varname, tok->linenr()); break; } - else if (tok1->previous() && tok1->previous()->str() == "&") + else if (Token::simpleMatch(tok1->previous(), "&")) { break; } - else if (tok1->next() && tok1->next()->str() == "=") + else if (Token::simpleMatch(tok1->next(), "=")) { break; } + // dereference in function call + else if (Token::Match(tok1->tokAt(-2), "[(,] *")) + { + nullPointerError(tok1, varname, tok->linenr()); + } } else if (tok1->str() == "{" || diff --git a/test/testother.cpp b/test/testother.cpp index cc8cb3069..6d638087f 100644 --- a/test/testother.cpp +++ b/test/testother.cpp @@ -911,7 +911,7 @@ private: " if (!p)\n" " ;\n" "}\n"); - ASSERT_EQUALS("[test.cpp:3]: (error) Possible null pointer dereference: p\n", errout.str()); + ASSERT_EQUALS("[test.cpp:3]: (error) Possible null pointer dereference: p - otherwise it is redundant to check if p is null at line 4\n", errout.str()); checkNullPointer("void foo(int *p)\n" "{\n" @@ -919,7 +919,7 @@ private: " if (!p)\n" " ;\n" "}\n"); - TODO_ASSERT_EQUALS("[test.cpp:3]: (error) Possible null pointer dereference: p\n", errout.str()); + ASSERT_EQUALS("[test.cpp:3]: (error) Possible null pointer dereference: p - otherwise it is redundant to check if p is null at line 4\n", errout.str()); // no error checkNullPointer("void foo()\n"