Applied patch 0001-Use-Token-simpleMatch-instead-of-Token-Match-w
Author: php-coder Ticket: http://apps.sourceforge.net/trac/cppcheck/ticket/323
This commit is contained in:
parent
47e10b75e3
commit
f182365bd2
|
@ -119,11 +119,11 @@ bool isStatic(const Token *tok)
|
||||||
{
|
{
|
||||||
bool res = false;
|
bool res = false;
|
||||||
|
|
||||||
if (Token::Match(tok->tokAt(-1), "static "))
|
if (Token::simpleMatch(tok->tokAt(-1), "static "))
|
||||||
res = true;
|
res = true;
|
||||||
else if (Token::Match(tok->tokAt(-2), "static "))
|
else if (Token::simpleMatch(tok->tokAt(-2), "static"))
|
||||||
res = true;
|
res = true;
|
||||||
else if (Token::Match(tok->tokAt(-3), "static "))
|
else if (Token::simpleMatch(tok->tokAt(-3), "static"))
|
||||||
res = true;
|
res = true;
|
||||||
|
|
||||||
//std::cout << __PRETTY_FUNCTION__ << " " << tok->str() << " " << res << std::endl;
|
//std::cout << __PRETTY_FUNCTION__ << " " << tok->str() << " " << res << std::endl;
|
||||||
|
@ -168,15 +168,15 @@ void CheckAutoVariables::autoVariables()
|
||||||
var_name = tok->tokAt(2)->str();
|
var_name = tok->tokAt(2)->str();
|
||||||
fp_list.push_back(var_name);
|
fp_list.push_back(var_name);
|
||||||
}
|
}
|
||||||
else if (begin_function && Token::Match(tok, "("))
|
else if (begin_function && Token::simpleMatch(tok, "("))
|
||||||
begin_function_decl = true;
|
begin_function_decl = true;
|
||||||
else if (begin_function && Token::Match(tok, ")"))
|
else if (begin_function && Token::simpleMatch(tok, ")"))
|
||||||
{
|
{
|
||||||
begin_function_decl = false;
|
begin_function_decl = false;
|
||||||
}
|
}
|
||||||
else if (begin_function && Token::Match(tok, "{"))
|
else if (begin_function && Token::simpleMatch(tok, "{"))
|
||||||
bindent++;
|
bindent++;
|
||||||
else if (begin_function && Token::Match(tok, "}"))
|
else if (begin_function && Token::simpleMatch(tok, "}"))
|
||||||
{
|
{
|
||||||
bindent--;
|
bindent--;
|
||||||
}
|
}
|
||||||
|
|
|
@ -318,7 +318,7 @@ void CheckClass::constructors()
|
||||||
// Are there a class constructor?
|
// Are there a class constructor?
|
||||||
std::string tempPattern = "%any% " + classNameToken->str() + " (";
|
std::string tempPattern = "%any% " + classNameToken->str() + " (";
|
||||||
const Token *constructor_token = Token::findmatch(tok1, tempPattern.c_str());
|
const Token *constructor_token = Token::findmatch(tok1, tempPattern.c_str());
|
||||||
while (Token::Match(constructor_token, "~"))
|
while (Token::simpleMatch(constructor_token, "~"))
|
||||||
constructor_token = Token::findmatch(constructor_token->next(), tempPattern.c_str());
|
constructor_token = Token::findmatch(constructor_token->next(), tempPattern.c_str());
|
||||||
|
|
||||||
// There are no constructor.
|
// There are no constructor.
|
||||||
|
@ -662,7 +662,7 @@ void CheckClass::virtualDestructor()
|
||||||
derived = derived->tokAt(3);
|
derived = derived->tokAt(3);
|
||||||
while (Token::Match(derived, "%var%"))
|
while (Token::Match(derived, "%var%"))
|
||||||
{
|
{
|
||||||
bool isPublic = Token::Match(derived, "public");
|
bool isPublic = Token::simpleMatch(derived, "public");
|
||||||
|
|
||||||
// What kind of inheritance is it.. public|protected|private
|
// What kind of inheritance is it.. public|protected|private
|
||||||
if (Token::Match(derived, "public|protected|private"))
|
if (Token::Match(derived, "public|protected|private"))
|
||||||
|
@ -675,7 +675,7 @@ void CheckClass::virtualDestructor()
|
||||||
|
|
||||||
// Update derived so it's ready for the next loop.
|
// Update derived so it's ready for the next loop.
|
||||||
derived = derived->next();
|
derived = derived->next();
|
||||||
if (Token::Match(derived, ","))
|
if (Token::simpleMatch(derived, ","))
|
||||||
derived = derived->next();
|
derived = derived->next();
|
||||||
|
|
||||||
// If not public inheritance, skip checking of this base class..
|
// If not public inheritance, skip checking of this base class..
|
||||||
|
@ -684,7 +684,7 @@ void CheckClass::virtualDestructor()
|
||||||
|
|
||||||
// Find the destructor declaration for the base class.
|
// Find the destructor declaration for the base class.
|
||||||
const Token *base = Token::findmatch(_tokenizer->tokens(), (std::string("%any% ~ ") + baseName[0] + " (").c_str());
|
const Token *base = Token::findmatch(_tokenizer->tokens(), (std::string("%any% ~ ") + baseName[0] + " (").c_str());
|
||||||
while (Token::Match(base, "::"))
|
while (Token::simpleMatch(base, "::"))
|
||||||
base = Token::findmatch(base->next(), (std::string("%any% ~ ") + baseName[0] + " (").c_str());
|
base = Token::findmatch(base->next(), (std::string("%any% ~ ") + baseName[0] + " (").c_str());
|
||||||
|
|
||||||
const Token *reverseTok = base;
|
const Token *reverseTok = base;
|
||||||
|
|
|
@ -68,9 +68,9 @@ void CheckFunctionUsage::parseTokens(const Tokenizer &tokenizer)
|
||||||
// Check that ") {" is found..
|
// Check that ") {" is found..
|
||||||
for (const Token *tok2 = funcname; tok2; tok2 = tok2->next())
|
for (const Token *tok2 = funcname; tok2; tok2 = tok2->next())
|
||||||
{
|
{
|
||||||
if (Token::Match(tok2, ")"))
|
if (Token::simpleMatch(tok2, ")"))
|
||||||
{
|
{
|
||||||
if (! Token::Match(tok2, ") {") && ! Token::Match(tok2, ") const {"))
|
if (! Token::simpleMatch(tok2, ") {") && ! Token::simpleMatch(tok2, ") const {"))
|
||||||
funcname = NULL;
|
funcname = NULL;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -120,7 +120,7 @@ void CheckFunctionUsage::parseTokens(const Tokenizer &tokenizer)
|
||||||
else if (tok2->str() == ")")
|
else if (tok2->str() == ")")
|
||||||
{
|
{
|
||||||
--parlevel;
|
--parlevel;
|
||||||
if (parlevel == 0 && (Token::Match(tok2, ") {") || Token::Match(tok2, ") const")))
|
if (parlevel == 0 && (Token::simpleMatch(tok2, ") {") || Token::simpleMatch(tok2, ") const")))
|
||||||
funcname = NULL;
|
funcname = NULL;
|
||||||
if (parlevel <= 0)
|
if (parlevel <= 0)
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -56,7 +56,7 @@ void CheckHeaders::WarningHeaderWithImplementation()
|
||||||
if (tok->fileIndex() == 0)
|
if (tok->fileIndex() == 0)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (Token::Match(tok, ") {"))
|
if (Token::simpleMatch(tok, ") {"))
|
||||||
{
|
{
|
||||||
std::ostringstream ostr;
|
std::ostringstream ostr;
|
||||||
ostr << _tokenizer->fileLine(tok) << ": Found implementation in header";
|
ostr << _tokenizer->fileLine(tok) << ": Found implementation in header";
|
||||||
|
|
|
@ -110,10 +110,10 @@ CheckMemoryLeakClass::AllocType CheckMemoryLeakClass::GetAllocationType(const To
|
||||||
if (Token::Match(tok2, "new %type% ["))
|
if (Token::Match(tok2, "new %type% ["))
|
||||||
return NewArray;
|
return NewArray;
|
||||||
|
|
||||||
if (Token::Match(tok2, "fopen ("))
|
if (Token::simpleMatch(tok2, "fopen ("))
|
||||||
return File;
|
return File;
|
||||||
|
|
||||||
if (Token::Match(tok2, "popen ("))
|
if (Token::simpleMatch(tok2, "popen ("))
|
||||||
return Pipe;
|
return Pipe;
|
||||||
|
|
||||||
// Userdefined allocation function..
|
// Userdefined allocation function..
|
||||||
|
@ -143,7 +143,7 @@ CheckMemoryLeakClass::AllocType CheckMemoryLeakClass::GetReallocationType(const
|
||||||
if (! tok2)
|
if (! tok2)
|
||||||
return No;
|
return No;
|
||||||
|
|
||||||
if (Token::Match(tok2, "realloc"))
|
if (Token::simpleMatch(tok2, "realloc"))
|
||||||
return Malloc;
|
return Malloc;
|
||||||
|
|
||||||
// GTK memory reallocation..
|
// GTK memory reallocation..
|
||||||
|
@ -810,7 +810,7 @@ void CheckMemoryLeakClass::simplifycode(Token *tok, bool &all)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Replace "{ }" with ";"
|
// Replace "{ }" with ";"
|
||||||
if (Token::Match(tok2->next(), "{ }"))
|
if (Token::simpleMatch(tok2->next(), "{ }"))
|
||||||
{
|
{
|
||||||
tok2->next()->str(";");
|
tok2->next()->str(";");
|
||||||
erase(tok2->next(), tok2->tokAt(3));
|
erase(tok2->next(), tok2->tokAt(3));
|
||||||
|
@ -842,7 +842,7 @@ void CheckMemoryLeakClass::simplifycode(Token *tok, bool &all)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Delete "if ; else ;"
|
// Delete "if ; else ;"
|
||||||
else if (Token::Match(tok2->next(), "if ; else ;"))
|
else if (Token::simpleMatch(tok2->next(), "if ; else ;"))
|
||||||
{
|
{
|
||||||
erase(tok2, tok2->tokAt(4));
|
erase(tok2, tok2->tokAt(4));
|
||||||
done = false;
|
done = false;
|
||||||
|
@ -882,7 +882,7 @@ void CheckMemoryLeakClass::simplifycode(Token *tok, bool &all)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Reduce "if if" => "if"
|
// Reduce "if if" => "if"
|
||||||
else if (Token::Match(tok2, "if if"))
|
else if (Token::simpleMatch(tok2, "if if"))
|
||||||
{
|
{
|
||||||
erase(tok2, tok2->tokAt(2));
|
erase(tok2, tok2->tokAt(2));
|
||||||
done = false;
|
done = false;
|
||||||
|
@ -911,14 +911,14 @@ void CheckMemoryLeakClass::simplifycode(Token *tok, bool &all)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Reduce "if ; else return use ;" => "if return use ;"
|
// Reduce "if ; else return use ;" => "if return use ;"
|
||||||
else if (Token::Match(tok2->next(), "if ; else return use ;"))
|
else if (Token::simpleMatch(tok2->next(), "if ; else return use ;"))
|
||||||
{
|
{
|
||||||
erase(tok2->next(), tok2->tokAt(4));
|
erase(tok2->next(), tok2->tokAt(4));
|
||||||
done = false;
|
done = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Reduce "if return ; if return ;" => "if return ;"
|
// Reduce "if return ; if return ;" => "if return ;"
|
||||||
else if (Token::Match(tok2->next(), "if return ; if return ;"))
|
else if (Token::simpleMatch(tok2->next(), "if return ; if return ;"))
|
||||||
{
|
{
|
||||||
erase(tok2, tok2->tokAt(4));
|
erase(tok2, tok2->tokAt(4));
|
||||||
done = false;
|
done = false;
|
||||||
|
@ -987,7 +987,7 @@ void CheckMemoryLeakClass::simplifycode(Token *tok, bool &all)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Reduce "else ;" => ";"
|
// Reduce "else ;" => ";"
|
||||||
if (Token::Match(tok2->next(), "else ;"))
|
if (Token::simpleMatch(tok2->next(), "else ;"))
|
||||||
{
|
{
|
||||||
erase(tok2, tok2->tokAt(2));
|
erase(tok2, tok2->tokAt(2));
|
||||||
done = false;
|
done = false;
|
||||||
|
@ -1002,7 +1002,7 @@ void CheckMemoryLeakClass::simplifycode(Token *tok, bool &all)
|
||||||
|
|
||||||
|
|
||||||
// Replace "dealloc use ;" with "dealloc ;"
|
// Replace "dealloc use ;" with "dealloc ;"
|
||||||
if (Token::Match(tok2, "dealloc use ;"))
|
if (Token::simpleMatch(tok2, "dealloc use ;"))
|
||||||
{
|
{
|
||||||
erase(tok2, tok2->tokAt(2));
|
erase(tok2, tok2->tokAt(2));
|
||||||
done = false;
|
done = false;
|
||||||
|
@ -1018,7 +1018,7 @@ void CheckMemoryLeakClass::simplifycode(Token *tok, bool &all)
|
||||||
|
|
||||||
// Reduce "do { alloc ; } " => "alloc ;"
|
// Reduce "do { alloc ; } " => "alloc ;"
|
||||||
// TODO: If the loop can be executed twice reduce to "loop alloc ;" instead
|
// TODO: If the loop can be executed twice reduce to "loop alloc ;" instead
|
||||||
if (Token::Match(tok2->next(), "do { alloc ; }"))
|
if (Token::simpleMatch(tok2->next(), "do { alloc ; }"))
|
||||||
{
|
{
|
||||||
erase(tok2, tok2->tokAt(3));
|
erase(tok2, tok2->tokAt(3));
|
||||||
erase(tok2->next()->next(), tok2->tokAt(4));
|
erase(tok2->next()->next(), tok2->tokAt(4));
|
||||||
|
@ -1052,7 +1052,7 @@ void CheckMemoryLeakClass::simplifycode(Token *tok, bool &all)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Replace "loop ;" with ";"
|
// Replace "loop ;" with ";"
|
||||||
if (Token::Match(tok2->next(), "loop ;"))
|
if (Token::simpleMatch(tok2->next(), "loop ;"))
|
||||||
{
|
{
|
||||||
erase(tok2, tok2->tokAt(2));
|
erase(tok2, tok2->tokAt(2));
|
||||||
done = false;
|
done = false;
|
||||||
|
@ -1073,7 +1073,7 @@ void CheckMemoryLeakClass::simplifycode(Token *tok, bool &all)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Replace "loop if return ;" with "if return ;"
|
// Replace "loop if return ;" with "if return ;"
|
||||||
if (Token::Match(tok2->next(), "loop if return"))
|
if (Token::simpleMatch(tok2->next(), "loop if return"))
|
||||||
{
|
{
|
||||||
erase(tok2, tok2->tokAt(2));
|
erase(tok2, tok2->tokAt(2));
|
||||||
done = false;
|
done = false;
|
||||||
|
@ -1130,7 +1130,7 @@ void CheckMemoryLeakClass::simplifycode(Token *tok, bool &all)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Reduce "if* alloc ; dealloc ;" => ";"
|
// Reduce "if* alloc ; dealloc ;" => ";"
|
||||||
if (Token::Match(tok2->tokAt(2), "alloc ; dealloc ;") &&
|
if (Token::simpleMatch(tok2->tokAt(2), "alloc ; dealloc ;") &&
|
||||||
tok2->next()->str().find("if") == 0)
|
tok2->next()->str().find("if") == 0)
|
||||||
{
|
{
|
||||||
erase(tok2, tok2->tokAt(5));
|
erase(tok2, tok2->tokAt(5));
|
||||||
|
@ -1159,14 +1159,14 @@ void CheckMemoryLeakClass::simplifycode(Token *tok, bool &all)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Delete second case in "case ; case ;"
|
// Delete second case in "case ; case ;"
|
||||||
while (Token::Match(tok2, "case ; case ;"))
|
while (Token::simpleMatch(tok2, "case ; case ;"))
|
||||||
{
|
{
|
||||||
erase(tok2, tok2->tokAt(3));
|
erase(tok2, tok2->tokAt(3));
|
||||||
done = false;
|
done = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Replace switch with if (if not complicated)
|
// Replace switch with if (if not complicated)
|
||||||
if (Token::Match(tok2, "switch {"))
|
if (Token::simpleMatch(tok2, "switch {"))
|
||||||
{
|
{
|
||||||
// Right now, I just handle if there are a few case and perhaps a default.
|
// Right now, I just handle if there are a few case and perhaps a default.
|
||||||
bool valid = false;
|
bool valid = false;
|
||||||
|
@ -1191,11 +1191,11 @@ void CheckMemoryLeakClass::simplifycode(Token *tok, bool &all)
|
||||||
else if (_tok->str() == "loop")
|
else if (_tok->str() == "loop")
|
||||||
break;
|
break;
|
||||||
|
|
||||||
else if (incase && Token::Match(_tok, "case"))
|
else if (incase && Token::simpleMatch(_tok, "case"))
|
||||||
break;
|
break;
|
||||||
|
|
||||||
incase |= Token::Match(_tok, "case");
|
incase |= Token::simpleMatch(_tok, "case");
|
||||||
incase &= !Token::Match(_tok, "break");
|
incase &= !Token::simpleMatch(_tok, "break");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!incase && valid)
|
if (!incase && valid)
|
||||||
|
@ -1205,9 +1205,9 @@ void CheckMemoryLeakClass::simplifycode(Token *tok, bool &all)
|
||||||
erase(tok2, tok2->tokAt(2));
|
erase(tok2, tok2->tokAt(2));
|
||||||
tok2 = tok2->next();
|
tok2 = tok2->next();
|
||||||
bool first = true;
|
bool first = true;
|
||||||
while (Token::Match(tok2, "case") || Token::Match(tok2, "default"))
|
while (Token::simpleMatch(tok2, "case") || Token::simpleMatch(tok2, "default"))
|
||||||
{
|
{
|
||||||
bool def = Token::Match(tok2, "default");
|
bool def = Token::simpleMatch(tok2, "default");
|
||||||
tok2->str(first ? "if" : "}");
|
tok2->str(first ? "if" : "}");
|
||||||
if (first)
|
if (first)
|
||||||
{
|
{
|
||||||
|
@ -1223,9 +1223,9 @@ void CheckMemoryLeakClass::simplifycode(Token *tok, bool &all)
|
||||||
tok2->insertToken("else");
|
tok2->insertToken("else");
|
||||||
tok2 = tok2->next();
|
tok2 = tok2->next();
|
||||||
}
|
}
|
||||||
while (tok2 && tok2->str() != "}" && ! Token::Match(tok2, "break ;"))
|
while (tok2 && tok2->str() != "}" && ! Token::simpleMatch(tok2, "break ;"))
|
||||||
tok2 = tok2->next();
|
tok2 = tok2->next();
|
||||||
if (Token::Match(tok2, "break ;"))
|
if (Token::simpleMatch(tok2, "break ;"))
|
||||||
{
|
{
|
||||||
tok2->str(";");
|
tok2->str(";");
|
||||||
tok2 = tok2->next()->next();
|
tok2 = tok2->next()->next();
|
||||||
|
@ -1349,16 +1349,16 @@ void CheckMemoryLeakClass::CheckMemoryLeak_CheckScope(const Token *Tok1, const c
|
||||||
first = first->next();
|
first = first->next();
|
||||||
|
|
||||||
bool noerr = false;
|
bool noerr = false;
|
||||||
noerr |= Token::Match(first, "alloc ; }");
|
noerr |= Token::simpleMatch(first, "alloc ; }");
|
||||||
noerr |= Token::Match(first, "alloc ; dealloc ; }");
|
noerr |= Token::simpleMatch(first, "alloc ; dealloc ; }");
|
||||||
noerr |= Token::Match(first, "alloc ; return use ; }");
|
noerr |= Token::simpleMatch(first, "alloc ; return use ; }");
|
||||||
noerr |= Token::Match(first, "alloc ; use ; }");
|
noerr |= Token::simpleMatch(first, "alloc ; use ; }");
|
||||||
noerr |= Token::Match(first, "alloc ; use ; return ; }");
|
noerr |= Token::simpleMatch(first, "alloc ; use ; return ; }");
|
||||||
noerr |= Token::Match(first, "if alloc ; dealloc ; }");
|
noerr |= Token::simpleMatch(first, "if alloc ; dealloc ; }");
|
||||||
noerr |= Token::Match(first, "if alloc ; return use ; }");
|
noerr |= Token::simpleMatch(first, "if alloc ; return use ; }");
|
||||||
noerr |= Token::Match(first, "if alloc ; use ; }");
|
noerr |= Token::simpleMatch(first, "if alloc ; use ; }");
|
||||||
noerr |= Token::Match(first, "alloc ; ifv return ; dealloc ; }");
|
noerr |= Token::simpleMatch(first, "alloc ; ifv return ; dealloc ; }");
|
||||||
noerr |= Token::Match(first, "alloc ; if return ; dealloc; }");
|
noerr |= Token::simpleMatch(first, "alloc ; if return ; dealloc; }");
|
||||||
|
|
||||||
// Unhandled case..
|
// Unhandled case..
|
||||||
if (! noerr)
|
if (! noerr)
|
||||||
|
@ -1397,7 +1397,7 @@ void CheckMemoryLeakClass::CheckMemoryLeak_InFunction()
|
||||||
// In function..
|
// In function..
|
||||||
if (indentlevel == 0)
|
if (indentlevel == 0)
|
||||||
{
|
{
|
||||||
if (Token::Match(tok, ") {"))
|
if (Token::simpleMatch(tok, ") {"))
|
||||||
infunc = true;
|
infunc = true;
|
||||||
|
|
||||||
else if (tok->str() == "::")
|
else if (tok->str() == "::")
|
||||||
|
|
|
@ -157,7 +157,7 @@ void CheckOther::redundantCondition2()
|
||||||
const Token *tok = Token::findmatch(_tokenizer->tokens(), pattern);
|
const Token *tok = Token::findmatch(_tokenizer->tokens(), pattern);
|
||||||
while (tok)
|
while (tok)
|
||||||
{
|
{
|
||||||
bool b = Token::Match(tok->tokAt(15), "{");
|
bool b = Token::simpleMatch(tok->tokAt(15), "{");
|
||||||
|
|
||||||
// Get tokens for the fields %var% and %any%
|
// Get tokens for the fields %var% and %any%
|
||||||
const Token *var1 = tok->tokAt(2);
|
const Token *var1 = tok->tokAt(2);
|
||||||
|
@ -317,11 +317,11 @@ void CheckOther::InvalidFunctionUsage()
|
||||||
int param = 1;
|
int param = 1;
|
||||||
for (const Token *tok2 = tok->next(); tok2; tok2 = tok2->next())
|
for (const Token *tok2 = tok->next(); tok2; tok2 = tok2->next())
|
||||||
{
|
{
|
||||||
if (Token::Match(tok2, "("))
|
if (Token::simpleMatch(tok2, "("))
|
||||||
++parlevel;
|
++parlevel;
|
||||||
else if (Token::Match(tok2, ")"))
|
else if (Token::simpleMatch(tok2, ")"))
|
||||||
--parlevel;
|
--parlevel;
|
||||||
else if (parlevel == 1 && Token::Match(tok2, ","))
|
else if (parlevel == 1 && Token::simpleMatch(tok2, ","))
|
||||||
{
|
{
|
||||||
++param;
|
++param;
|
||||||
if (param == 3)
|
if (param == 3)
|
||||||
|
@ -508,7 +508,7 @@ void CheckOther::CheckVariableScope()
|
||||||
if (indentlevel == 0)
|
if (indentlevel == 0)
|
||||||
func = false;
|
func = false;
|
||||||
}
|
}
|
||||||
if (indentlevel == 0 && Token::Match(tok, ") {"))
|
if (indentlevel == 0 && Token::simpleMatch(tok, ") {"))
|
||||||
{
|
{
|
||||||
func = true;
|
func = true;
|
||||||
}
|
}
|
||||||
|
@ -543,7 +543,7 @@ void CheckOther::CheckVariableScope_LookupVar(const Token *tok1, const char varn
|
||||||
const Token *tok = tok1;
|
const Token *tok = tok1;
|
||||||
|
|
||||||
// Skip the variable declaration..
|
// Skip the variable declaration..
|
||||||
while (tok && !Token::Match(tok, ";"))
|
while (tok && !Token::simpleMatch(tok, ";"))
|
||||||
tok = tok->next();
|
tok = tok->next();
|
||||||
|
|
||||||
// Check if the variable is used in this indentlevel..
|
// Check if the variable is used in this indentlevel..
|
||||||
|
@ -778,12 +778,12 @@ void CheckOther::CheckIncompleteStatement()
|
||||||
if (parlevel != 0)
|
if (parlevel != 0)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (Token::Match(tok, "= {"))
|
if (Token::simpleMatch(tok, "= {"))
|
||||||
{
|
{
|
||||||
/* We are in an assignment, so it's not a statement.
|
/* We are in an assignment, so it's not a statement.
|
||||||
* Skip until ";" */
|
* Skip until ";" */
|
||||||
|
|
||||||
while (!Token::Match(tok, ";"))
|
while (!Token::simpleMatch(tok, ";"))
|
||||||
{
|
{
|
||||||
int level = 0;
|
int level = 0;
|
||||||
do
|
do
|
||||||
|
|
|
@ -141,7 +141,7 @@ void CheckStl::erase()
|
||||||
{
|
{
|
||||||
for (const Token *tok = _tokenizer->tokens(); tok; tok = tok->next())
|
for (const Token *tok = _tokenizer->tokens(); tok; tok = tok->next())
|
||||||
{
|
{
|
||||||
if (Token::Match(tok, "for ("))
|
if (Token::simpleMatch(tok, "for ("))
|
||||||
{
|
{
|
||||||
for (const Token *tok2 = tok->tokAt(2); tok2 && tok2->str() != ";"; tok2 = tok2->next())
|
for (const Token *tok2 = tok->tokAt(2); tok2 && tok2->str() != ";"; tok2 = tok2->next())
|
||||||
{
|
{
|
||||||
|
@ -262,7 +262,7 @@ void CheckStl::pushback()
|
||||||
// Iterator becomes invalid after push_back or push_front..
|
// Iterator becomes invalid after push_back or push_front..
|
||||||
for (const Token *tok = _tokenizer->tokens(); tok; tok = tok->next())
|
for (const Token *tok = _tokenizer->tokens(); tok; tok = tok->next())
|
||||||
{
|
{
|
||||||
if (Token::Match(tok, "vector <"))
|
if (Token::simpleMatch(tok, "vector <"))
|
||||||
{
|
{
|
||||||
while (tok && tok->str() != ">")
|
while (tok && tok->str() != ">")
|
||||||
tok = tok->next();
|
tok = tok->next();
|
||||||
|
@ -336,7 +336,7 @@ void CheckStl::stlBoundries()
|
||||||
for (const Token *tok = _tokenizer->tokens(); tok; tok = tok->next())
|
for (const Token *tok = _tokenizer->tokens(); tok; tok = tok->next())
|
||||||
{
|
{
|
||||||
// Declaring iterator..
|
// Declaring iterator..
|
||||||
if (Token::Match(tok, "list <"))
|
if (Token::simpleMatch(tok, "list <"))
|
||||||
{
|
{
|
||||||
while (tok && tok->str() != ">")
|
while (tok && tok->str() != ">")
|
||||||
tok = tok->next();
|
tok = tok->next();
|
||||||
|
|
|
@ -861,7 +861,7 @@ public:
|
||||||
{
|
{
|
||||||
if (tok->str() == ")")
|
if (tok->str() == ")")
|
||||||
break;
|
break;
|
||||||
if (Token::Match(tok, ". . . )"))
|
if (Token::simpleMatch(tok, ". . . )"))
|
||||||
{
|
{
|
||||||
_variadic = true;
|
_variadic = true;
|
||||||
break;
|
break;
|
||||||
|
@ -959,7 +959,7 @@ public:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (_variadic && Token::Match(tok, ",") && tok->next() && Token::Match(tok->next(), "##"))
|
if (_variadic && Token::simpleMatch(tok, ",") && tok->next() && Token::simpleMatch(tok->next(), "##"))
|
||||||
{
|
{
|
||||||
optcomma = true;
|
optcomma = true;
|
||||||
continue;
|
continue;
|
||||||
|
|
|
@ -1159,26 +1159,26 @@ void Tokenizer::simplifyTokenList()
|
||||||
{
|
{
|
||||||
if (Token::Match(tempToken, "%var%"))
|
if (Token::Match(tempToken, "%var%"))
|
||||||
{
|
{
|
||||||
if (Token::Match(tempToken->next(), "."))
|
if (Token::simpleMatch(tempToken->next(), "."))
|
||||||
{
|
{
|
||||||
// We are checking a class or struct, search next varname
|
// We are checking a class or struct, search next varname
|
||||||
tempToken = tempToken->tokAt(1);
|
tempToken = tempToken->tokAt(1);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
else if (Token::Match(tempToken->next(), "- >"))
|
else if (Token::simpleMatch(tempToken->next(), "- >"))
|
||||||
{
|
{
|
||||||
// We are checking a class or struct, search next varname
|
// We are checking a class or struct, search next varname
|
||||||
tempToken = tempToken->tokAt(2);
|
tempToken = tempToken->tokAt(2);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
else if (Token::Match(tempToken->next(), "++") ||
|
else if (Token::simpleMatch(tempToken->next(), "++") ||
|
||||||
Token::Match(tempToken->next(), "--"))
|
Token::simpleMatch(tempToken->next(), "--"))
|
||||||
{
|
{
|
||||||
// We have variable++ or variable--, there should be
|
// We have variable++ or variable--, there should be
|
||||||
// nothing after this
|
// nothing after this
|
||||||
tempToken = tempToken->tokAt(2);
|
tempToken = tempToken->tokAt(2);
|
||||||
}
|
}
|
||||||
else if (Token::Match(tempToken->next(), "["))
|
else if (Token::simpleMatch(tempToken->next(), "["))
|
||||||
{
|
{
|
||||||
// TODO: We need to find closing ], then check for
|
// TODO: We need to find closing ], then check for
|
||||||
// dots and arrows "var[some[0]]->other"
|
// dots and arrows "var[some[0]]->other"
|
||||||
|
@ -2136,7 +2136,7 @@ bool Tokenizer::simplifyIfNot()
|
||||||
for (Token *tok = _tokens; tok; tok = tok->next())
|
for (Token *tok = _tokens; tok; tok = tok->next())
|
||||||
{
|
{
|
||||||
|
|
||||||
if (Token::Match(tok, "0 == (") ||
|
if (Token::simpleMatch(tok, "0 == (") ||
|
||||||
Token::Match(tok, "0 == %var%"))
|
Token::Match(tok, "0 == %var%"))
|
||||||
{
|
{
|
||||||
tok->deleteNext();
|
tok->deleteNext();
|
||||||
|
@ -2152,7 +2152,7 @@ bool Tokenizer::simplifyIfNot()
|
||||||
ret = true;
|
ret = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tok->link() && Token::Match(tok, ") == 0"))
|
if (tok->link() && Token::simpleMatch(tok, ") == 0"))
|
||||||
{
|
{
|
||||||
tok->deleteNext();
|
tok->deleteNext();
|
||||||
tok->deleteNext();
|
tok->deleteNext();
|
||||||
|
@ -2220,13 +2220,13 @@ bool Tokenizer::simplifyKnownVariables()
|
||||||
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
else if (tok3->str() == "{" && Token::Match(tok3->previous(), ")"))
|
else if (tok3->str() == "{" && Token::simpleMatch(tok3->previous(), ")"))
|
||||||
{
|
{
|
||||||
// There is a possible loop after the assignment. Try to skip it.
|
// There is a possible loop after the assignment. Try to skip it.
|
||||||
bailOutFromLoop = tok3->link();
|
bailOutFromLoop = tok3->link();
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
else if (tok3->str() == "}" && Token::Match(tok3->link()->previous(), ")"))
|
else if (tok3->str() == "}" && Token::simpleMatch(tok3->link()->previous(), ")"))
|
||||||
{
|
{
|
||||||
// Assignment was in the middle of possible loop, bail out.
|
// Assignment was in the middle of possible loop, bail out.
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in New Issue