STL: don't warn about the suspicious string::find condition because it's not always a bug

This commit is contained in:
Daniel Marjamäki 2010-03-03 17:11:31 +01:00
parent 75c0ed7e6e
commit e207da18a2
2 changed files with 1 additions and 24 deletions

View File

@ -556,12 +556,8 @@ void CheckStl::if_find()
decl = decl->next(); decl = decl->next();
// string..
if (_settings->_showAll && Token::Match(decl, "const| std :: string &|*| %varid%", varid))
if_findError(tok, true);
// stl container // stl container
else if (Token::Match(decl, "const| std :: %var% < %type% > &|*| %varid%", varid)) if (Token::Match(decl, "const| std :: %var% < %type% > &|*| %varid%", varid))
if_findError(tok, false); if_findError(tok, false);
} }
} }

View File

@ -646,25 +646,6 @@ private:
void if_find() void if_find()
{ {
// ---------------------------
// string::find
// ---------------------------
// error
check("void f(std::string s)\n"
"{\n"
" if (s.find(\"ab\")) { }\n"
"}\n");
ASSERT_EQUALS("[test.cpp:3]: (possible style) Suspicious condition. string::find will return 0 if the string is found at position 0. If this is what you want to check then string::compare is a faster alternative because it doesn't scan through the string.\n", errout.str());
// ok
check("void f(std::string s)\n"
"{\n"
" if (s.find(\"ab\") != std::string::npos) { }\n"
"}\n");
ASSERT_EQUALS("", errout.str());
// --------------------------- // ---------------------------
// set::find // set::find
// --------------------------- // ---------------------------