Change every 'tokAt(..)->link()' to 'linkAt(..)'.
This commit is contained in:
parent
690702a742
commit
42e369a4b4
|
@ -146,7 +146,7 @@ void CheckAssignIf::multiCondition()
|
||||||
if (num1 < 0)
|
if (num1 < 0)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
const Token *tok2 = tok->tokAt(6)->link();
|
const Token *tok2 = tok->linkAt(6);
|
||||||
while (Token::simpleMatch(tok2, "} else { if (")) {
|
while (Token::simpleMatch(tok2, "} else { if (")) {
|
||||||
// Goto '('
|
// Goto '('
|
||||||
const Token * const opar = tok2->tokAt(4);
|
const Token * const opar = tok2->tokAt(4);
|
||||||
|
|
|
@ -139,7 +139,7 @@ void CheckAutoVariables::autoVariables()
|
||||||
else if (Token::Match(tok, "return & %var% ;") && isAutoVar(tok->tokAt(2)->varId())) {
|
else if (Token::Match(tok, "return & %var% ;") && isAutoVar(tok->tokAt(2)->varId())) {
|
||||||
errorReturnAddressToAutoVariable(tok);
|
errorReturnAddressToAutoVariable(tok);
|
||||||
} else if (Token::Match(tok, "return & %var% [") &&
|
} else if (Token::Match(tok, "return & %var% [") &&
|
||||||
Token::simpleMatch(tok->tokAt(3)->link(), "] ;") &&
|
Token::simpleMatch(tok->linkAt(3), "] ;") &&
|
||||||
isAutoVarArray(tok->tokAt(2)->varId())) {
|
isAutoVarArray(tok->tokAt(2)->varId())) {
|
||||||
errorReturnAddressToAutoVariable(tok);
|
errorReturnAddressToAutoVariable(tok);
|
||||||
} else if (Token::Match(tok, "return & %var% ;") && tok->tokAt(2)->varId()) {
|
} else if (Token::Match(tok, "return & %var% ;") && tok->tokAt(2)->varId()) {
|
||||||
|
|
|
@ -654,7 +654,7 @@ void CheckBufferOverrun::checkFunctionParameter(const Token &tok, unsigned int p
|
||||||
// goto end of if block..
|
// goto end of if block..
|
||||||
ftok = ftok->next()->link()->next()->link();
|
ftok = ftok->next()->link()->next()->link();
|
||||||
if (Token::simpleMatch(ftok, "} else {"))
|
if (Token::simpleMatch(ftok, "} else {"))
|
||||||
ftok = ftok->tokAt(2)->link();
|
ftok = ftok->linkAt(2);
|
||||||
if (!ftok)
|
if (!ftok)
|
||||||
break;
|
break;
|
||||||
continue;
|
continue;
|
||||||
|
@ -1438,13 +1438,13 @@ void CheckBufferOverrun::checkStructVariable()
|
||||||
// check for allocation
|
// check for allocation
|
||||||
if ((Token::Match(tok3->tokAt(3), "; %var% = malloc ( %num% ) ;") ||
|
if ((Token::Match(tok3->tokAt(3), "; %var% = malloc ( %num% ) ;") ||
|
||||||
(Token::Match(tok3->tokAt(3), "; %var% = (") &&
|
(Token::Match(tok3->tokAt(3), "; %var% = (") &&
|
||||||
Token::Match(tok3->tokAt(6)->link(), ") malloc ( %num% ) ;"))) &&
|
Token::Match(tok3->linkAt(6), ") malloc ( %num% ) ;"))) &&
|
||||||
(tok3->strAt(4) == tok3->strAt(2))) {
|
(tok3->strAt(4) == tok3->strAt(2))) {
|
||||||
MathLib::bigint size;
|
MathLib::bigint size;
|
||||||
|
|
||||||
// find size of allocation
|
// find size of allocation
|
||||||
if (tok3->strAt(3) == "(") // has cast
|
if (tok3->strAt(3) == "(") // has cast
|
||||||
size = MathLib::toLongNumber(tok3->tokAt(6)->link()->strAt(3));
|
size = MathLib::toLongNumber(tok3->linkAt(6)->strAt(3));
|
||||||
else
|
else
|
||||||
size = MathLib::toLongNumber(tok3->strAt(8));
|
size = MathLib::toLongNumber(tok3->strAt(8));
|
||||||
|
|
||||||
|
|
|
@ -336,7 +336,7 @@ void CheckClass::initializeVarList(const Function &func, std::list<std::string>
|
||||||
else if (Token::Match(ftok, "::| memset ( %var% ,")) {
|
else if (Token::Match(ftok, "::| memset ( %var% ,")) {
|
||||||
const int offset = ftok->str() == "::" ? 1 : 0;
|
const int offset = ftok->str() == "::" ? 1 : 0;
|
||||||
assignVar(ftok->strAt(2 + offset), scope, usage);
|
assignVar(ftok->strAt(2 + offset), scope, usage);
|
||||||
ftok = ftok->tokAt(1 + offset)->link();
|
ftok = ftok->linkAt(1 + offset);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -819,7 +819,7 @@ void CheckClass::checkReturnPtrThis(const Scope *scope, const Function *func, co
|
||||||
|
|
||||||
// check if a function is called
|
// check if a function is called
|
||||||
if (Token::Match(tok->tokAt(1), "%any% (") &&
|
if (Token::Match(tok->tokAt(1), "%any% (") &&
|
||||||
tok->tokAt(2)->link()->next()->str() == ";") {
|
tok->linkAt(2)->next()->str() == ";") {
|
||||||
std::list<Function>::const_iterator it;
|
std::list<Function>::const_iterator it;
|
||||||
|
|
||||||
// check if it is a member function
|
// check if it is a member function
|
||||||
|
@ -1037,7 +1037,7 @@ void CheckClass::virtualDestructor()
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
// Empty destructor
|
// Empty destructor
|
||||||
if (destructor->token->tokAt(3)->link() == destructor->token->tokAt(4))
|
if (destructor->token->linkAt(3) == destructor->token->tokAt(4))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
const Token *derived = scope->classDef;
|
const Token *derived = scope->classDef;
|
||||||
|
@ -1283,7 +1283,7 @@ bool CheckClass::isMemberVar(const Scope *scope, const Token *tok)
|
||||||
tok = tok->tokAt(-2);
|
tok = tok->tokAt(-2);
|
||||||
again = true;
|
again = true;
|
||||||
} else if (Token::Match(tok->tokAt(-2), "] . %var%")) {
|
} else if (Token::Match(tok->tokAt(-2), "] . %var%")) {
|
||||||
tok = tok->tokAt(-2)->link()->previous();
|
tok = tok->linkAt(-2)->previous();
|
||||||
again = true;
|
again = true;
|
||||||
} else if (tok->str() == "]") {
|
} else if (tok->str() == "]") {
|
||||||
tok = tok->link()->previous();
|
tok = tok->link()->previous();
|
||||||
|
|
|
@ -923,7 +923,7 @@ Token *CheckMemoryLeakInFunction::getcode(const Token *tok, std::list<const Toke
|
||||||
|
|
||||||
// var = strcpy|.. ( var ,
|
// var = strcpy|.. ( var ,
|
||||||
if (Token::Match(tok, "[;{}] %varid% = memcpy|memmove|memset|strcpy|strncpy|strcat|strncat ( %varid% ,", varid)) {
|
if (Token::Match(tok, "[;{}] %varid% = memcpy|memmove|memset|strcpy|strncpy|strcat|strncat ( %varid% ,", varid)) {
|
||||||
tok = tok->tokAt(4)->link();
|
tok = tok->linkAt(4);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1002,7 +1002,7 @@ Token *CheckMemoryLeakInFunction::getcode(const Token *tok, std::list<const Toke
|
||||||
alloctype = alloc;
|
alloctype = alloc;
|
||||||
|
|
||||||
if (Token::Match(tok, "%var% = %type% (")) {
|
if (Token::Match(tok, "%var% = %type% (")) {
|
||||||
tok = tok->tokAt(3)->link();
|
tok = tok->linkAt(3);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1053,7 +1053,7 @@ Token *CheckMemoryLeakInFunction::getcode(const Token *tok, std::list<const Toke
|
||||||
dealloctype = dealloc;
|
dealloctype = dealloc;
|
||||||
|
|
||||||
if (tok->strAt(2) == "(")
|
if (tok->strAt(2) == "(")
|
||||||
tok = tok->tokAt(2)->link();
|
tok = tok->linkAt(2);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2265,12 +2265,12 @@ void CheckMemoryLeakInFunction::checkReallocUsage()
|
||||||
Token::findmatch(startOfFunction, "[{};] %varid% = %var% [;=]", tok->varId()))
|
Token::findmatch(startOfFunction, "[{};] %varid% = %var% [;=]", tok->varId()))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
const Token* tokEndRealloc = tok->tokAt(3)->link();
|
const Token* tokEndRealloc = tok->linkAt(3);
|
||||||
// Check that the allocation isn't followed immediately by an 'if (!var) { error(); }' that might handle failure
|
// Check that the allocation isn't followed immediately by an 'if (!var) { error(); }' that might handle failure
|
||||||
if (Token::Match(tokEndRealloc->tokAt(1), "; if ( ! %varid% ) {", tok->varId())) {
|
if (Token::Match(tokEndRealloc->tokAt(1), "; if ( ! %varid% ) {", tok->varId())) {
|
||||||
const Token* tokEndBrace = tokEndRealloc->tokAt(7)->link();
|
const Token* tokEndBrace = tokEndRealloc->linkAt(7);
|
||||||
if (tokEndBrace && Token::simpleMatch(tokEndBrace->tokAt(-2), ") ;") &&
|
if (tokEndBrace && Token::simpleMatch(tokEndBrace->tokAt(-2), ") ;") &&
|
||||||
Token::Match(tokEndBrace->tokAt(-2)->link()->tokAt(-2), "{|}|; %var% ("))
|
Token::Match(tokEndBrace->linkAt(-2)->tokAt(-2), "{|}|; %var% ("))
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2284,12 +2284,12 @@ void CheckMemoryLeakInFunction::checkReallocUsage()
|
||||||
Token::findmatch(startOfFunction, "[{};] * %varid% = %var% [;=]", tok->tokAt(1)->varId()))
|
Token::findmatch(startOfFunction, "[{};] * %varid% = %var% [;=]", tok->tokAt(1)->varId()))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
const Token* tokEndRealloc = tok->tokAt(4)->link();
|
const Token* tokEndRealloc = tok->linkAt(4);
|
||||||
// Check that the allocation isn't followed immediately by an 'if (!var) { error(); }' that might handle failure
|
// Check that the allocation isn't followed immediately by an 'if (!var) { error(); }' that might handle failure
|
||||||
if (Token::Match(tokEndRealloc->tokAt(1), "; if ( ! * %varid% ) {", tok->tokAt(1)->varId())) {
|
if (Token::Match(tokEndRealloc->tokAt(1), "; if ( ! * %varid% ) {", tok->tokAt(1)->varId())) {
|
||||||
const Token* tokEndBrace = tokEndRealloc->tokAt(8)->link();
|
const Token* tokEndBrace = tokEndRealloc->linkAt(8);
|
||||||
if (tokEndBrace && Token::simpleMatch(tokEndBrace->tokAt(-2), ") ;") &&
|
if (tokEndBrace && Token::simpleMatch(tokEndBrace->tokAt(-2), ") ;") &&
|
||||||
Token::Match(tokEndBrace->tokAt(-2)->link()->tokAt(-2), "{|}|; %var% ("))
|
Token::Match(tokEndBrace->linkAt(-2)->tokAt(-2), "{|}|; %var% ("))
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
memleakUponReallocFailureError(tok->tokAt(1), tok->strAt(1));
|
memleakUponReallocFailureError(tok->tokAt(1), tok->strAt(1));
|
||||||
|
@ -2887,7 +2887,7 @@ void CheckMemoryLeakNoVar::check()
|
||||||
// parse the executable scope until tok is reached...
|
// parse the executable scope until tok is reached...
|
||||||
for (const Token *tok2 = tok->link(); tok2 && tok2 != tok; tok2 = tok2->next()) {
|
for (const Token *tok2 = tok->link(); tok2 && tok2 != tok; tok2 = tok2->next()) {
|
||||||
// allocating memory in parameter for function call..
|
// allocating memory in parameter for function call..
|
||||||
if (Token::Match(tok2, "[(,] %var% (") && Token::Match(tok2->tokAt(2)->link(), ") [,)]")) {
|
if (Token::Match(tok2, "[(,] %var% (") && Token::Match(tok2->linkAt(2), ") [,)]")) {
|
||||||
const AllocType allocType = getAllocationType(tok2->next(), 0);
|
const AllocType allocType = getAllocationType(tok2->next(), 0);
|
||||||
if (allocType != No) {
|
if (allocType != No) {
|
||||||
// locate outer function call..
|
// locate outer function call..
|
||||||
|
|
|
@ -561,7 +561,7 @@ void CheckNullPointer::nullPointerStructByDeRefAndChec()
|
||||||
// Function call: If the pointer is not a local variable it
|
// Function call: If the pointer is not a local variable it
|
||||||
// might be changed by the call.
|
// might be changed by the call.
|
||||||
else if (Token::Match(tok2, "[;{}] %var% (") &&
|
else if (Token::Match(tok2, "[;{}] %var% (") &&
|
||||||
Token::simpleMatch(tok2->tokAt(2)->link(), ") ;") && !isLocal) {
|
Token::simpleMatch(tok2->linkAt(2), ") ;") && !isLocal) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -794,7 +794,7 @@ void CheckNullPointer::nullPointerByCheckAndDeRef()
|
||||||
if (null && indentlevel == 0) {
|
if (null && indentlevel == 0) {
|
||||||
// skip all "else" blocks because they are not executed in this execution path
|
// skip all "else" blocks because they are not executed in this execution path
|
||||||
while (Token::simpleMatch(tok2, "} else {"))
|
while (Token::simpleMatch(tok2, "} else {"))
|
||||||
tok2 = tok2->tokAt(2)->link();
|
tok2 = tok2->linkAt(2);
|
||||||
null = false;
|
null = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -769,10 +769,10 @@ void CheckOther::checkSelfAssignment()
|
||||||
// check if the linenr is the same for all the tokens.
|
// check if the linenr is the same for all the tokens.
|
||||||
if (Token::Match(tok->tokAt(-2), ") { %var% = %var% ; } else { %varid% =", tok->varId())) {
|
if (Token::Match(tok->tokAt(-2), ") { %var% = %var% ; } else { %varid% =", tok->varId())) {
|
||||||
// Find the 'if' token
|
// Find the 'if' token
|
||||||
const Token *tokif = tok->tokAt(-2)->link()->previous();
|
const Token *tokif = tok->linkAt(-2)->previous();
|
||||||
|
|
||||||
// find the '}' that terminates the 'else'-block
|
// find the '}' that terminates the 'else'-block
|
||||||
const Token *else_end = tok->tokAt(6)->link();
|
const Token *else_end = tok->linkAt(6);
|
||||||
|
|
||||||
if (tokif && else_end && tokif->linenr() == else_end->linenr())
|
if (tokif && else_end && tokif->linenr() == else_end->linenr())
|
||||||
err = false;
|
err = false;
|
||||||
|
@ -1048,7 +1048,7 @@ void CheckOther::checkCatchExceptionByValue()
|
||||||
|
|
||||||
const char catchPattern[] = "} catch (";
|
const char catchPattern[] = "} catch (";
|
||||||
const Token *tok = Token::findmatch(_tokenizer->tokens(), catchPattern);
|
const Token *tok = Token::findmatch(_tokenizer->tokens(), catchPattern);
|
||||||
const Token *endTok = tok ? tok->tokAt(2)->link() : NULL;
|
const Token *endTok = tok ? tok->linkAt(2) : NULL;
|
||||||
|
|
||||||
while (tok && endTok) {
|
while (tok && endTok) {
|
||||||
// Find a pass-by-value declaration in the catch(), excluding basic types
|
// Find a pass-by-value declaration in the catch(), excluding basic types
|
||||||
|
@ -1059,7 +1059,7 @@ void CheckOther::checkCatchExceptionByValue()
|
||||||
}
|
}
|
||||||
|
|
||||||
tok = Token::findmatch(endTok->next(), catchPattern);
|
tok = Token::findmatch(endTok->next(), catchPattern);
|
||||||
endTok = tok ? tok->tokAt(2)->link() : NULL;
|
endTok = tok ? tok->linkAt(2) : NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2069,7 +2069,7 @@ static bool isFunction(const std::string &name, const Token *startToken)
|
||||||
if (Token::simpleMatch(tok, ") {"))
|
if (Token::simpleMatch(tok, ") {"))
|
||||||
tok = tok->next()->link();
|
tok = tok->next()->link();
|
||||||
else if (Token::simpleMatch(tok, ") const {"))
|
else if (Token::simpleMatch(tok, ") const {"))
|
||||||
tok = tok->tokAt(2)->link();
|
tok = tok->linkAt(2);
|
||||||
}
|
}
|
||||||
|
|
||||||
// function declaration/implementation found
|
// function declaration/implementation found
|
||||||
|
@ -2108,7 +2108,7 @@ void CheckOther::checkMisusedScopedObject()
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Token::Match(tok, "[;{}] %var% (")
|
if (Token::Match(tok, "[;{}] %var% (")
|
||||||
&& Token::simpleMatch(tok->tokAt(2)->link(), ") ;")
|
&& Token::simpleMatch(tok->linkAt(2), ") ;")
|
||||||
&& symbolDatabase->isClassOrStruct(tok->next()->str())
|
&& symbolDatabase->isClassOrStruct(tok->next()->str())
|
||||||
&& !isFunction(tok->next()->str(), _tokenizer->tokens())) {
|
&& !isFunction(tok->next()->str(), _tokenizer->tokens())) {
|
||||||
tok = tok->next();
|
tok = tok->next();
|
||||||
|
@ -2146,7 +2146,7 @@ void CheckOther::checkIncorrectStringCompare()
|
||||||
}
|
}
|
||||||
if (Token::Match(tok, "&&|%oror% %str% &&|%oror%|)")) {
|
if (Token::Match(tok, "&&|%oror% %str% &&|%oror%|)")) {
|
||||||
// assert(condition && "debug message") would be considered a fp.
|
// assert(condition && "debug message") would be considered a fp.
|
||||||
if (tok->str() == "&&" && tok->strAt(2) == ")" && tok->tokAt(2)->link()->previous()->str() == "assert")
|
if (tok->str() == "&&" && tok->strAt(2) == ")" && tok->linkAt(2)->previous()->str() == "assert")
|
||||||
continue;
|
continue;
|
||||||
incorrectStringBooleanError(tok->tokAt(1), tok->strAt(1));
|
incorrectStringBooleanError(tok->tokAt(1), tok->strAt(1));
|
||||||
}
|
}
|
||||||
|
@ -2256,9 +2256,9 @@ void CheckOther::checkDuplicateIf()
|
||||||
|
|
||||||
// check all the else if (...) statements
|
// check all the else if (...) statements
|
||||||
while (Token::simpleMatch(tok1, "} else if (") &&
|
while (Token::simpleMatch(tok1, "} else if (") &&
|
||||||
Token::simpleMatch(tok1->tokAt(3)->link(), ") {")) {
|
Token::simpleMatch(tok1->linkAt(3), ") {")) {
|
||||||
// get the expression from the token stream
|
// get the expression from the token stream
|
||||||
expression = stringifyTokens(tok1->tokAt(4), tok1->tokAt(3)->link()->previous());
|
expression = stringifyTokens(tok1->tokAt(4), tok1->linkAt(3)->previous());
|
||||||
|
|
||||||
// try to look up the expression to check for duplicates
|
// try to look up the expression to check for duplicates
|
||||||
std::map<std::string, const Token *>::iterator it = expressionMap.find(expression);
|
std::map<std::string, const Token *>::iterator it = expressionMap.find(expression);
|
||||||
|
@ -2266,7 +2266,7 @@ void CheckOther::checkDuplicateIf()
|
||||||
// found a duplicate
|
// found a duplicate
|
||||||
if (it != expressionMap.end()) {
|
if (it != expressionMap.end()) {
|
||||||
// check for expressions that have side effects and ignore them
|
// check for expressions that have side effects and ignore them
|
||||||
if (!expressionHasSideEffects(tok1->tokAt(4), tok1->tokAt(3)->link()->previous()))
|
if (!expressionHasSideEffects(tok1->tokAt(4), tok1->linkAt(3)->previous()))
|
||||||
duplicateIfError(it->second, tok1->next());
|
duplicateIfError(it->second, tok1->next());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2275,7 +2275,7 @@ void CheckOther::checkDuplicateIf()
|
||||||
expressionMap.insert(std::make_pair(expression, tok1->next()));
|
expressionMap.insert(std::make_pair(expression, tok1->next()));
|
||||||
|
|
||||||
// find the next else if (...) statement
|
// find the next else if (...) statement
|
||||||
tok1 = tok1->tokAt(3)->link()->next()->link();
|
tok1 = tok1->linkAt(3)->next()->link();
|
||||||
}
|
}
|
||||||
|
|
||||||
tok = tok->next()->link()->next();
|
tok = tok->next()->link()->next();
|
||||||
|
@ -2329,7 +2329,7 @@ void CheckOther::checkDuplicateBranch()
|
||||||
const Token *tok1 = tok->next()->link()->next()->link();
|
const Token *tok1 = tok->next()->link()->next()->link();
|
||||||
|
|
||||||
// save else branch code
|
// save else branch code
|
||||||
std::string branch2 = stringifyTokens(tok1->tokAt(3), tok1->tokAt(2)->link()->previous());
|
std::string branch2 = stringifyTokens(tok1->tokAt(3), tok1->linkAt(2)->previous());
|
||||||
|
|
||||||
// check for duplicates
|
// check for duplicates
|
||||||
if (branch1 == branch2)
|
if (branch1 == branch2)
|
||||||
|
|
|
@ -120,7 +120,7 @@ void CheckStl::iterators()
|
||||||
validIterator = true;
|
validIterator = true;
|
||||||
|
|
||||||
// skip the operation
|
// skip the operation
|
||||||
tok2 = tok2->tokAt(5)->link();
|
tok2 = tok2->linkAt(5);
|
||||||
if (!tok2)
|
if (!tok2)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -621,7 +621,7 @@ void CheckStl::pushback()
|
||||||
}
|
}
|
||||||
|
|
||||||
invalidIterator = tok2->strAt(2);
|
invalidIterator = tok2->strAt(2);
|
||||||
tok2 = tok2->tokAt(3)->link();
|
tok2 = tok2->linkAt(3);
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: instead of bail out for 'else' try to check all execution paths.
|
// TODO: instead of bail out for 'else' try to check all execution paths.
|
||||||
|
@ -958,7 +958,7 @@ void CheckStl::missingComparison()
|
||||||
incrementToken = 0;
|
incrementToken = 0;
|
||||||
else if (Token::Match(tok3, "%varid% = %var% . insert ( ++| %varid% ++| ,", iteratorId)) {
|
else if (Token::Match(tok3, "%varid% = %var% . insert ( ++| %varid% ++| ,", iteratorId)) {
|
||||||
// skip insertion..
|
// skip insertion..
|
||||||
tok3 = tok3->tokAt(6)->link();
|
tok3 = tok3->linkAt(6);
|
||||||
if (!tok3)
|
if (!tok3)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -1024,7 +1024,7 @@ void CheckStl::string_c_str()
|
||||||
pointers.find(tok->next()->varId()) != pointers.end()) {
|
pointers.find(tok->next()->varId()) != pointers.end()) {
|
||||||
string_c_strError(tok);
|
string_c_strError(tok);
|
||||||
} else if (Token::Match(tok, "[;{}] %var% = %var% (") &&
|
} else if (Token::Match(tok, "[;{}] %var% = %var% (") &&
|
||||||
Token::simpleMatch(tok->tokAt(4)->link(), ") . c_str ( ) ;") &&
|
Token::simpleMatch(tok->linkAt(4), ") . c_str ( ) ;") &&
|
||||||
tok->next()->varId() > 0 &&
|
tok->next()->varId() > 0 &&
|
||||||
pointers.find(tok->next()->varId()) != pointers.end() &&
|
pointers.find(tok->next()->varId()) != pointers.end() &&
|
||||||
Token::findmatch(_tokenizer->tokens(), ("std :: string " + tok->strAt(3) + " (").c_str())) {
|
Token::findmatch(_tokenizer->tokens(), ("std :: string " + tok->strAt(3) + " (").c_str())) {
|
||||||
|
@ -1047,7 +1047,7 @@ void CheckStl::string_c_str()
|
||||||
localvar.find(tok->next()->varId()) != localvar.end()) {
|
localvar.find(tok->next()->varId()) != localvar.end()) {
|
||||||
string_c_strError(tok, true);
|
string_c_strError(tok, true);
|
||||||
} else if (Token::simpleMatch(tok, "return std :: string (") &&
|
} else if (Token::simpleMatch(tok, "return std :: string (") &&
|
||||||
Token::simpleMatch(tok->tokAt(4)->link(), ") . c_str ( ) ;")) {
|
Token::simpleMatch(tok->linkAt(4), ") . c_str ( ) ;")) {
|
||||||
string_c_strError(tok, true);
|
string_c_strError(tok, true);
|
||||||
} else if (Token::simpleMatch(tok, "return (") &&
|
} else if (Token::simpleMatch(tok, "return (") &&
|
||||||
Token::simpleMatch(tok->next()->link(), ") . c_str ( ) ;")) {
|
Token::simpleMatch(tok->next()->link(), ") . c_str ( ) ;")) {
|
||||||
|
@ -1189,7 +1189,7 @@ void CheckStl::uselessCalls()
|
||||||
if (tok->varId() == 0)
|
if (tok->varId() == 0)
|
||||||
continue;
|
continue;
|
||||||
/*if (Token::Match(tok, "%var% . compare (") &&
|
/*if (Token::Match(tok, "%var% . compare (") &&
|
||||||
tok->varId() == tok->tokAt(3)->link()->tokAt(-1)->varId()) {
|
tok->varId() == tok->linkAt(3)->tokAt(-1)->varId()) {
|
||||||
uselessCallsReturnValueError(tok, tok->tokAt(2));
|
uselessCallsReturnValueError(tok, tok->tokAt(2));
|
||||||
} else */
|
} else */
|
||||||
if (Token::Match(tok, "%var% . compare|find|rfind|find_first_not_of|find_first_of|find_last_not_of|find_last_of ( %var% [,)]") &&
|
if (Token::Match(tok, "%var% . compare|find|rfind|find_first_not_of|find_first_of|find_last_not_of|find_last_of ( %var% [,)]") &&
|
||||||
|
@ -1202,7 +1202,7 @@ void CheckStl::uselessCalls()
|
||||||
uselessCallsSubstrError(tok, tok->str());
|
uselessCallsSubstrError(tok, tok->str());
|
||||||
} else if (Token::Match(tok, "%var% . substr ( 0")) {
|
} else if (Token::Match(tok, "%var% . substr ( 0")) {
|
||||||
if (tok->strAt(5) == ")" ||
|
if (tok->strAt(5) == ")" ||
|
||||||
tok->tokAt(3)->link()->strAt(-1) == "npos")
|
tok->linkAt(3)->strAt(-1) == "npos")
|
||||||
uselessCallsSubstrError(tok, tok->str());
|
uselessCallsSubstrError(tok, tok->str());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -409,7 +409,7 @@ private:
|
||||||
// Variable declaration..
|
// Variable declaration..
|
||||||
if (Token::Match(tok.previous(), "[;{}] %var%") && tok.str() != "return") {
|
if (Token::Match(tok.previous(), "[;{}] %var%") && tok.str() != "return") {
|
||||||
if (Token::Match(&tok, "enum %type% {"))
|
if (Token::Match(&tok, "enum %type% {"))
|
||||||
return tok.tokAt(2)->link();
|
return tok.linkAt(2);
|
||||||
|
|
||||||
const Token * vartok = &tok;
|
const Token * vartok = &tok;
|
||||||
while (Token::Match(vartok, "const|struct"))
|
while (Token::Match(vartok, "const|struct"))
|
||||||
|
@ -427,7 +427,7 @@ private:
|
||||||
// Variable declaration for array..
|
// Variable declaration for array..
|
||||||
if (Token::Match(vartok, "%type% %var% [") &&
|
if (Token::Match(vartok, "%type% %var% [") &&
|
||||||
vartok->isStandardType() &&
|
vartok->isStandardType() &&
|
||||||
Token::simpleMatch(vartok->tokAt(2)->link(), "] ;")) {
|
Token::simpleMatch(vartok->linkAt(2), "] ;")) {
|
||||||
vartok = vartok->next();
|
vartok = vartok->next();
|
||||||
declare(checks, vartok, tok, false, true);
|
declare(checks, vartok, tok, false, true);
|
||||||
return vartok->next()->link();
|
return vartok->next()->link();
|
||||||
|
@ -916,7 +916,7 @@ public:
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (tok->str() != "::" && Token::Match(tok->next(), "%var% ( %type%")) {
|
if (tok->str() != "::" && Token::Match(tok->next(), "%var% ( %type%")) {
|
||||||
if (!Token::Match(tok->tokAt(2)->link(), ") [{;]"))
|
if (!Token::Match(tok->linkAt(2), ") [{;]"))
|
||||||
continue;
|
continue;
|
||||||
const Token *tok2 = tok->tokAt(3);
|
const Token *tok2 = tok->tokAt(3);
|
||||||
while (tok2 && tok2->str() != ")") {
|
while (tok2 && tok2->str() != ")") {
|
||||||
|
|
|
@ -1294,7 +1294,7 @@ void CheckUnusedVar::checkStructMemberUsage()
|
||||||
structname.clear();
|
structname.clear();
|
||||||
if (Token::simpleMatch(tok->previous(), "extern"))
|
if (Token::simpleMatch(tok->previous(), "extern"))
|
||||||
continue;
|
continue;
|
||||||
if ((!tok->previous() || Token::simpleMatch(tok->previous(), ";")) && Token::Match(tok->tokAt(2)->link(), ("} ; " + tok->strAt(1) + " %var% ;").c_str()))
|
if ((!tok->previous() || Token::simpleMatch(tok->previous(), ";")) && Token::Match(tok->linkAt(2), ("} ; " + tok->strAt(1) + " %var% ;").c_str()))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
structname = tok->strAt(1);
|
structname = tok->strAt(1);
|
||||||
|
|
|
@ -138,8 +138,8 @@ void ExecutionPath::checkScope(const Token *tok, std::list<ExecutionPath *> &che
|
||||||
for (; tok; tok = tok->next()) {
|
for (; tok; tok = tok->next()) {
|
||||||
// might be a noreturn function..
|
// might be a noreturn function..
|
||||||
if (Token::simpleMatch(tok->tokAt(-2), ") ; }") &&
|
if (Token::simpleMatch(tok->tokAt(-2), ") ; }") &&
|
||||||
Token::Match(tok->tokAt(-2)->link()->tokAt(-2), "[;{}] %var% (") &&
|
Token::Match(tok->linkAt(-2)->tokAt(-2), "[;{}] %var% (") &&
|
||||||
tok->tokAt(-2)->link()->previous()->varId() == 0) {
|
tok->linkAt(-2)->previous()->varId() == 0) {
|
||||||
ExecutionPath::bailOut(checks);
|
ExecutionPath::bailOut(checks);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -161,9 +161,9 @@ void ExecutionPath::checkScope(const Token *tok, std::list<ExecutionPath *> &che
|
||||||
|
|
||||||
// skip "while (fgets()!=NULL)"
|
// skip "while (fgets()!=NULL)"
|
||||||
if (Token::simpleMatch(tok, "while ( fgets (")) {
|
if (Token::simpleMatch(tok, "while ( fgets (")) {
|
||||||
const Token *tok2 = tok->tokAt(3)->link();
|
const Token *tok2 = tok->linkAt(3);
|
||||||
if (Token::simpleMatch(tok2, ") ) {")) {
|
if (Token::simpleMatch(tok2, ") ) {")) {
|
||||||
tok = tok2->tokAt(2)->link();
|
tok = tok2->linkAt(2);
|
||||||
if (!tok)
|
if (!tok)
|
||||||
break;
|
break;
|
||||||
continue;
|
continue;
|
||||||
|
@ -252,7 +252,7 @@ void ExecutionPath::checkScope(const Token *tok, std::list<ExecutionPath *> &che
|
||||||
// #2231 - loop body only contains a conditional initialization..
|
// #2231 - loop body only contains a conditional initialization..
|
||||||
if (Token::simpleMatch(tok2->next(), "if (")) {
|
if (Token::simpleMatch(tok2->next(), "if (")) {
|
||||||
// Start { for the if block
|
// Start { for the if block
|
||||||
const Token *tok3 = tok2->tokAt(2)->link();
|
const Token *tok3 = tok2->linkAt(2);
|
||||||
if (Token::simpleMatch(tok3,") {")) {
|
if (Token::simpleMatch(tok3,") {")) {
|
||||||
tok3 = tok3->next();
|
tok3 = tok3->next();
|
||||||
|
|
||||||
|
@ -286,7 +286,7 @@ void ExecutionPath::checkScope(const Token *tok, std::list<ExecutionPath *> &che
|
||||||
|
|
||||||
// if "do { .. } while ( .." , goto end of while..
|
// if "do { .. } while ( .." , goto end of while..
|
||||||
if (Token::simpleMatch(tok, "do {") && Token::simpleMatch(tok2, "} while ("))
|
if (Token::simpleMatch(tok, "do {") && Token::simpleMatch(tok2, "} while ("))
|
||||||
tok2 = tok2->tokAt(2)->link();
|
tok2 = tok2->linkAt(2);
|
||||||
|
|
||||||
// bail out all variables if the scope contains a "return"
|
// bail out all variables if the scope contains a "return"
|
||||||
// bail out all variables used in this for/while/switch/do
|
// bail out all variables used in this for/while/switch/do
|
||||||
|
|
|
@ -420,7 +420,7 @@ SymbolDatabase::SymbolDatabase(const Tokenizer *tokenizer, const Settings *setti
|
||||||
|
|
||||||
// function returning function pointer with body
|
// function returning function pointer with body
|
||||||
else if (Token::simpleMatch(argStart->link(), ") ) (") &&
|
else if (Token::simpleMatch(argStart->link(), ") ) (") &&
|
||||||
Token::Match(argStart->link()->tokAt(2)->link(), ") const| {")) {
|
Token::Match(argStart->link()->linkAt(2), ") const| {")) {
|
||||||
const Token *tok1 = funcStart;
|
const Token *tok1 = funcStart;
|
||||||
Scope *old_scope = scope;
|
Scope *old_scope = scope;
|
||||||
|
|
||||||
|
@ -480,9 +480,9 @@ SymbolDatabase::SymbolDatabase(const Tokenizer *tokenizer, const Settings *setti
|
||||||
|
|
||||||
// function returning function pointer prototype
|
// function returning function pointer prototype
|
||||||
else if (Token::simpleMatch(argStart->link(), ") ) (") &&
|
else if (Token::simpleMatch(argStart->link(), ") ) (") &&
|
||||||
Token::simpleMatch(argStart->link()->tokAt(2)->link(), ") ;")) {
|
Token::simpleMatch(argStart->link()->linkAt(2), ") ;")) {
|
||||||
/** @todo save function prototypes in database someday */
|
/** @todo save function prototypes in database someday */
|
||||||
tok = argStart->link()->tokAt(2)->link()->next();
|
tok = argStart->link()->linkAt(2)->next();
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -501,8 +501,8 @@ SymbolDatabase::SymbolDatabase(const Tokenizer *tokenizer, const Settings *setti
|
||||||
scope = &scopeList.back();
|
scope = &scopeList.back();
|
||||||
scope->nestedIn->nestedList.push_back(scope);
|
scope->nestedIn->nestedList.push_back(scope);
|
||||||
} else if (Token::simpleMatch(tok, "else if (") &&
|
} else if (Token::simpleMatch(tok, "else if (") &&
|
||||||
Token::simpleMatch(tok->tokAt(2)->link(), ") {")) {
|
Token::simpleMatch(tok->linkAt(2), ") {")) {
|
||||||
const Token *tok1 = tok->tokAt(2)->link()->next();
|
const Token *tok1 = tok->linkAt(2)->next();
|
||||||
scopeList.push_back(Scope(this, tok, scope, Scope::eElseIf, tok1));
|
scopeList.push_back(Scope(this, tok, scope, Scope::eElseIf, tok1));
|
||||||
tok = tok1;
|
tok = tok1;
|
||||||
scope = &scopeList.back();
|
scope = &scopeList.back();
|
||||||
|
@ -989,7 +989,7 @@ void SymbolDatabase::addFunction(Scope **scope, const Token **tok, const Token *
|
||||||
func->hasBody = true;
|
func->hasBody = true;
|
||||||
func->token = *tok;
|
func->token = *tok;
|
||||||
func->arg = argStart;
|
func->arg = argStart;
|
||||||
const Token *start = argStart->link()->tokAt(2)->link()->next();
|
const Token *start = argStart->link()->linkAt(2)->next();
|
||||||
while (start && start->str() != "{")
|
while (start && start->str() != "{")
|
||||||
start = start->next();
|
start = start->next();
|
||||||
func->start = start;
|
func->start = start;
|
||||||
|
|
134
lib/tokenize.cpp
134
lib/tokenize.cpp
|
@ -748,7 +748,7 @@ static Token *splitDefinitionFromTypedef(Token *tok)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tok->strAt(2) == "{") { // unnamed
|
if (tok->strAt(2) == "{") { // unnamed
|
||||||
tok1 = tok->tokAt(2)->link();
|
tok1 = tok->linkAt(2);
|
||||||
|
|
||||||
if (tok1 && tok1->next()) {
|
if (tok1 && tok1->next()) {
|
||||||
// use typedef name if available
|
// use typedef name if available
|
||||||
|
@ -772,7 +772,7 @@ static Token *splitDefinitionFromTypedef(Token *tok)
|
||||||
|
|
||||||
name = tok->strAt(2);
|
name = tok->strAt(2);
|
||||||
} else { // has a name
|
} else { // has a name
|
||||||
tok1 = tok->tokAt(3)->link();
|
tok1 = tok->linkAt(3);
|
||||||
|
|
||||||
if (!tok1)
|
if (!tok1)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -816,18 +816,18 @@ static Token *processFunc(Token *tok2, bool inOperator)
|
||||||
tok2->next()->str() != ",") {
|
tok2->next()->str() != ",") {
|
||||||
// skip over tokens for some types of canonicalization
|
// skip over tokens for some types of canonicalization
|
||||||
if (Token::Match(tok2->next(), "( * %type% ) ("))
|
if (Token::Match(tok2->next(), "( * %type% ) ("))
|
||||||
tok2 = tok2->tokAt(5)->link();
|
tok2 = tok2->linkAt(5);
|
||||||
else if (Token::Match(tok2->next(), "* ( * %type% ) ("))
|
else if (Token::Match(tok2->next(), "* ( * %type% ) ("))
|
||||||
tok2 = tok2->tokAt(6)->link();
|
tok2 = tok2->linkAt(6);
|
||||||
else if (Token::Match(tok2->next(), "* ( * %type% ) ;"))
|
else if (Token::Match(tok2->next(), "* ( * %type% ) ;"))
|
||||||
tok2 = tok2->tokAt(5);
|
tok2 = tok2->tokAt(5);
|
||||||
else if (Token::Match(tok2->next(), "* ( %type% [") &&
|
else if (Token::Match(tok2->next(), "* ( %type% [") &&
|
||||||
Token::Match(tok2->tokAt(4)->link(), "] ) ;|="))
|
Token::Match(tok2->linkAt(4), "] ) ;|="))
|
||||||
tok2 = tok2->tokAt(4)->link()->next();
|
tok2 = tok2->linkAt(4)->next();
|
||||||
else if (Token::Match(tok2->next(), "* ( * %type% ("))
|
else if (Token::Match(tok2->next(), "* ( * %type% ("))
|
||||||
tok2 = tok2->tokAt(5)->link()->next();
|
tok2 = tok2->linkAt(5)->next();
|
||||||
else if (Token::Match(tok2->next(), "* [") &&
|
else if (Token::Match(tok2->next(), "* [") &&
|
||||||
Token::simpleMatch(tok2->tokAt(2)->link(), "] ;"))
|
Token::simpleMatch(tok2->linkAt(2), "] ;"))
|
||||||
tok2 = tok2->next();
|
tok2 = tok2->next();
|
||||||
else {
|
else {
|
||||||
if (tok2->next()->str() == "(")
|
if (tok2->next()->str() == "(")
|
||||||
|
@ -1100,7 +1100,7 @@ void Tokenizer::simplifyTypedef()
|
||||||
// unhandled function pointer, skip it and continue
|
// unhandled function pointer, skip it and continue
|
||||||
// TODO: handle such typedefs. See ticket #3314
|
// TODO: handle such typedefs. See ticket #3314
|
||||||
else if (Token::Match(tok->tokAt(offset), "( %type% ::") &&
|
else if (Token::Match(tok->tokAt(offset), "( %type% ::") &&
|
||||||
Token::Match(tok->tokAt(offset)->link()->tokAt(-3), ":: * %var% ) (")) {
|
Token::Match(tok->linkAt(offset)->tokAt(-3), ":: * %var% ) (")) {
|
||||||
unsupportedTypedef(typeDef);
|
unsupportedTypedef(typeDef);
|
||||||
tok = deleteInvalidTypedef(typeDef);
|
tok = deleteInvalidTypedef(typeDef);
|
||||||
continue;
|
continue;
|
||||||
|
@ -1115,19 +1115,19 @@ void Tokenizer::simplifyTypedef()
|
||||||
funcEnd = tok->tokAt(offset + 1);
|
funcEnd = tok->tokAt(offset + 1);
|
||||||
typeName = tok->tokAt(offset + 2);
|
typeName = tok->tokAt(offset + 2);
|
||||||
argStart = tok->tokAt(offset + 4);
|
argStart = tok->tokAt(offset + 4);
|
||||||
argEnd = tok->tokAt(offset + 4)->link();
|
argEnd = tok->linkAt(offset + 4);
|
||||||
tok = argEnd->next();
|
tok = argEnd->next();
|
||||||
}
|
}
|
||||||
|
|
||||||
// function
|
// function
|
||||||
else if (Token::Match(tok->tokAt(offset)->link(), ") const| ;|,")) {
|
else if (Token::Match(tok->linkAt(offset), ") const| ;|,")) {
|
||||||
function = true;
|
function = true;
|
||||||
if (tok->tokAt(offset)->link()->next()->str() == "const") {
|
if (tok->linkAt(offset)->next()->str() == "const") {
|
||||||
specStart = tok->tokAt(offset)->link()->next();
|
specStart = tok->linkAt(offset)->next();
|
||||||
specEnd = specStart;
|
specEnd = specStart;
|
||||||
}
|
}
|
||||||
argStart = tok->tokAt(offset);
|
argStart = tok->tokAt(offset);
|
||||||
argEnd = tok->tokAt(offset)->link();
|
argEnd = tok->linkAt(offset);
|
||||||
tok = argEnd->next();
|
tok = argEnd->next();
|
||||||
if (specStart)
|
if (specStart)
|
||||||
tok = tok->next();
|
tok = tok->next();
|
||||||
|
@ -1150,10 +1150,10 @@ void Tokenizer::simplifyTypedef()
|
||||||
|
|
||||||
// typeof: typedef __typeof__ ( ... ) type;
|
// typeof: typedef __typeof__ ( ... ) type;
|
||||||
else if (Token::simpleMatch(tok->tokAt(offset - 1), "__typeof__ (") &&
|
else if (Token::simpleMatch(tok->tokAt(offset - 1), "__typeof__ (") &&
|
||||||
Token::Match(tok->tokAt(offset)->link(), ") %type% ;")) {
|
Token::Match(tok->linkAt(offset), ") %type% ;")) {
|
||||||
argStart = tok->tokAt(offset);
|
argStart = tok->tokAt(offset);
|
||||||
argEnd = tok->tokAt(offset)->link();
|
argEnd = tok->linkAt(offset);
|
||||||
typeName = tok->tokAt(offset)->link()->next();
|
typeName = tok->linkAt(offset)->next();
|
||||||
tok = typeName->next();
|
tok = typeName->next();
|
||||||
typeOf = true;
|
typeOf = true;
|
||||||
}
|
}
|
||||||
|
@ -1162,14 +1162,14 @@ void Tokenizer::simplifyTypedef()
|
||||||
// typedef ... (( .... type )( ... ));
|
// typedef ... (( .... type )( ... ));
|
||||||
// typedef ... ( * ( .... type )( ... ));
|
// typedef ... ( * ( .... type )( ... ));
|
||||||
else if ((tok->strAt(offset) == "(" &&
|
else if ((tok->strAt(offset) == "(" &&
|
||||||
Token::Match(tok->tokAt(offset)->link()->previous(), "%type% ) (") &&
|
Token::Match(tok->linkAt(offset)->previous(), "%type% ) (") &&
|
||||||
Token::Match(tok->tokAt(offset)->link()->next()->link(), ") const|volatile|;")) ||
|
Token::Match(tok->linkAt(offset)->next()->link(), ") const|volatile|;")) ||
|
||||||
(Token::simpleMatch(tok->tokAt(offset), "( (") &&
|
(Token::simpleMatch(tok->tokAt(offset), "( (") &&
|
||||||
Token::Match(tok->tokAt(offset + 1)->link()->previous(), "%type% ) (") &&
|
Token::Match(tok->linkAt(offset + 1)->previous(), "%type% ) (") &&
|
||||||
Token::Match(tok->tokAt(offset + 1)->link()->next()->link(), ") const|volatile| ) ;|,")) ||
|
Token::Match(tok->linkAt(offset + 1)->next()->link(), ") const|volatile| ) ;|,")) ||
|
||||||
(Token::simpleMatch(tok->tokAt(offset), "( * (") &&
|
(Token::simpleMatch(tok->tokAt(offset), "( * (") &&
|
||||||
Token::Match(tok->tokAt(offset + 2)->link()->previous(), "%type% ) (") &&
|
Token::Match(tok->linkAt(offset + 2)->previous(), "%type% ) (") &&
|
||||||
Token::Match(tok->tokAt(offset + 2)->link()->next()->link(), ") const|volatile| ) ;|,"))) {
|
Token::Match(tok->linkAt(offset + 2)->next()->link(), ") const|volatile| ) ;|,"))) {
|
||||||
if (tok->strAt(offset + 1) == "(")
|
if (tok->strAt(offset + 1) == "(")
|
||||||
++offset;
|
++offset;
|
||||||
else if (Token::simpleMatch(tok->tokAt(offset), "( * (")) {
|
else if (Token::simpleMatch(tok->tokAt(offset), "( * (")) {
|
||||||
|
@ -1178,15 +1178,15 @@ void Tokenizer::simplifyTypedef()
|
||||||
++offset;
|
++offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tok->tokAt(offset)->link()->strAt(-2) == "*")
|
if (tok->linkAt(offset)->strAt(-2) == "*")
|
||||||
functionPtr = true;
|
functionPtr = true;
|
||||||
else
|
else
|
||||||
function = true;
|
function = true;
|
||||||
funcStart = tok->tokAt(offset + 1);
|
funcStart = tok->tokAt(offset + 1);
|
||||||
funcEnd = tok->tokAt(offset)->link()->tokAt(-2);
|
funcEnd = tok->linkAt(offset)->tokAt(-2);
|
||||||
typeName = tok->tokAt(offset)->link()->previous();
|
typeName = tok->linkAt(offset)->previous();
|
||||||
argStart = tok->tokAt(offset)->link()->next();
|
argStart = tok->linkAt(offset)->next();
|
||||||
argEnd = tok->tokAt(offset)->link()->next()->link();
|
argEnd = tok->linkAt(offset)->next()->link();
|
||||||
tok = argEnd->next();
|
tok = argEnd->next();
|
||||||
Token *spec = tok;
|
Token *spec = tok;
|
||||||
if (Token::Match(spec, "const|volatile")) {
|
if (Token::Match(spec, "const|volatile")) {
|
||||||
|
@ -1204,11 +1204,11 @@ void Tokenizer::simplifyTypedef()
|
||||||
|
|
||||||
else if (Token::Match(tok->tokAt(offset), "( %type% (")) {
|
else if (Token::Match(tok->tokAt(offset), "( %type% (")) {
|
||||||
function = true;
|
function = true;
|
||||||
if (tok->tokAt(offset)->link()->next()) {
|
if (tok->linkAt(offset)->next()) {
|
||||||
typeName = tok->tokAt(offset + 1);
|
typeName = tok->tokAt(offset + 1);
|
||||||
argStart = tok->tokAt(offset + 2);
|
argStart = tok->tokAt(offset + 2);
|
||||||
argEnd = tok->tokAt(offset + 2)->link();
|
argEnd = tok->linkAt(offset + 2);
|
||||||
tok = tok->tokAt(offset)->link()->next();
|
tok = tok->linkAt(offset)->next();
|
||||||
} else {
|
} else {
|
||||||
// internal error
|
// internal error
|
||||||
continue;
|
continue;
|
||||||
|
@ -1217,32 +1217,32 @@ void Tokenizer::simplifyTypedef()
|
||||||
|
|
||||||
// pointer to function returning pointer to function
|
// pointer to function returning pointer to function
|
||||||
else if (Token::Match(tok->tokAt(offset), "( * ( * %type% ) (") &&
|
else if (Token::Match(tok->tokAt(offset), "( * ( * %type% ) (") &&
|
||||||
Token::simpleMatch(tok->tokAt(offset + 6)->link(), ") ) (") &&
|
Token::simpleMatch(tok->linkAt(offset + 6), ") ) (") &&
|
||||||
Token::Match(tok->tokAt(offset + 6)->link()->tokAt(2)->link(), ") ;|,")) {
|
Token::Match(tok->linkAt(offset + 6)->linkAt(2), ") ;|,")) {
|
||||||
functionPtrRetFuncPtr = true;
|
functionPtrRetFuncPtr = true;
|
||||||
|
|
||||||
typeName = tok->tokAt(offset + 4);
|
typeName = tok->tokAt(offset + 4);
|
||||||
argStart = tok->tokAt(offset + 6);
|
argStart = tok->tokAt(offset + 6);
|
||||||
argEnd = tok->tokAt(offset + 6)->link();
|
argEnd = tok->linkAt(offset + 6);
|
||||||
|
|
||||||
argFuncRetStart = argEnd->tokAt(2);
|
argFuncRetStart = argEnd->tokAt(2);
|
||||||
argFuncRetEnd = argEnd->tokAt(2)->link();
|
argFuncRetEnd = argEnd->linkAt(2);
|
||||||
|
|
||||||
tok = argFuncRetEnd->next();
|
tok = argFuncRetEnd->next();
|
||||||
}
|
}
|
||||||
|
|
||||||
// function returning pointer to function
|
// function returning pointer to function
|
||||||
else if (Token::Match(tok->tokAt(offset), "( * %type% (") &&
|
else if (Token::Match(tok->tokAt(offset), "( * %type% (") &&
|
||||||
Token::simpleMatch(tok->tokAt(offset + 3)->link(), ") ) (") &&
|
Token::simpleMatch(tok->linkAt(offset + 3), ") ) (") &&
|
||||||
Token::Match(tok->tokAt(offset + 3)->link()->tokAt(2)->link(), ") ;|,")) {
|
Token::Match(tok->linkAt(offset + 3)->linkAt(2), ") ;|,")) {
|
||||||
functionRetFuncPtr = true;
|
functionRetFuncPtr = true;
|
||||||
|
|
||||||
typeName = tok->tokAt(offset + 2);
|
typeName = tok->tokAt(offset + 2);
|
||||||
argStart = tok->tokAt(offset + 3);
|
argStart = tok->tokAt(offset + 3);
|
||||||
argEnd = tok->tokAt(offset + 3)->link();
|
argEnd = tok->linkAt(offset + 3);
|
||||||
|
|
||||||
argFuncRetStart = argEnd->tokAt(2);
|
argFuncRetStart = argEnd->tokAt(2);
|
||||||
argFuncRetEnd = argEnd->tokAt(2)->link();
|
argFuncRetEnd = argEnd->linkAt(2);
|
||||||
|
|
||||||
tok = argFuncRetEnd->next();
|
tok = argFuncRetEnd->next();
|
||||||
} else if (Token::Match(tok->tokAt(offset), "( * ( %type% ) (")) {
|
} else if (Token::Match(tok->tokAt(offset), "( * ( %type% ) (")) {
|
||||||
|
@ -1250,10 +1250,10 @@ void Tokenizer::simplifyTypedef()
|
||||||
|
|
||||||
typeName = tok->tokAt(offset + 3);
|
typeName = tok->tokAt(offset + 3);
|
||||||
argStart = tok->tokAt(offset + 5);
|
argStart = tok->tokAt(offset + 5);
|
||||||
argEnd = tok->tokAt(offset + 5)->link();
|
argEnd = tok->linkAt(offset + 5);
|
||||||
|
|
||||||
argFuncRetStart = argEnd->tokAt(2);
|
argFuncRetStart = argEnd->tokAt(2);
|
||||||
argFuncRetEnd = argEnd->tokAt(2)->link();
|
argFuncRetEnd = argEnd->linkAt(2);
|
||||||
|
|
||||||
tok = argFuncRetEnd->next();
|
tok = argFuncRetEnd->next();
|
||||||
}
|
}
|
||||||
|
@ -1334,7 +1334,7 @@ void Tokenizer::simplifyTypedef()
|
||||||
else if (tok2->str() == "operator" &&
|
else if (tok2->str() == "operator" &&
|
||||||
tok2->next()->str() == typeName->str() &&
|
tok2->next()->str() == typeName->str() &&
|
||||||
tok2->strAt(2) == "(" &&
|
tok2->strAt(2) == "(" &&
|
||||||
Token::Match(tok2->tokAt(2)->link(), ") const| {")) {
|
Token::Match(tok2->linkAt(2), ") const| {")) {
|
||||||
// check for qualifier
|
// check for qualifier
|
||||||
if (tok2->previous()->str() == "::") {
|
if (tok2->previous()->str() == "::") {
|
||||||
// check for available and matching class name
|
// check for available and matching class name
|
||||||
|
@ -1706,7 +1706,7 @@ void Tokenizer::simplifyTypedef()
|
||||||
tok2 = copyTokens(tok2, argStart, argEnd);
|
tok2 = copyTokens(tok2, argStart, argEnd);
|
||||||
} else if (tok2->tokAt(2) && tok2->strAt(2) == "[") {
|
} else if (tok2->tokAt(2) && tok2->strAt(2) == "[") {
|
||||||
while (tok2->tokAt(2) && tok2->strAt(2) == "[")
|
while (tok2->tokAt(2) && tok2->strAt(2) == "[")
|
||||||
tok2 = tok2->tokAt(2)->link()->previous();
|
tok2 = tok2->linkAt(2)->previous();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (arrayStart && arrayEnd) {
|
if (arrayStart && arrayEnd) {
|
||||||
|
@ -1971,7 +1971,7 @@ bool Tokenizer::tokenize(std::istream &code,
|
||||||
// check for simple syntax errors..
|
// check for simple syntax errors..
|
||||||
for (const Token *tok = _tokens; tok; tok = tok->next()) {
|
for (const Token *tok = _tokens; tok; tok = tok->next()) {
|
||||||
if (Token::simpleMatch(tok, "> struct {") &&
|
if (Token::simpleMatch(tok, "> struct {") &&
|
||||||
Token::simpleMatch(tok->tokAt(2)->link(), "} ;")) {
|
Token::simpleMatch(tok->linkAt(2), "} ;")) {
|
||||||
syntaxError(tok);
|
syntaxError(tok);
|
||||||
deallocateTokens();
|
deallocateTokens();
|
||||||
return false;
|
return false;
|
||||||
|
@ -2077,7 +2077,7 @@ bool Tokenizer::tokenize(std::istream &code,
|
||||||
if (Token::simpleMatch(tok, "try {")) {
|
if (Token::simpleMatch(tok, "try {")) {
|
||||||
tok = tok->next()->link();
|
tok = tok->next()->link();
|
||||||
while (Token::simpleMatch(tok, "} catch (")) {
|
while (Token::simpleMatch(tok, "} catch (")) {
|
||||||
tok = tok->tokAt(2)->link();
|
tok = tok->linkAt(2);
|
||||||
if (Token::simpleMatch(tok, ") {"))
|
if (Token::simpleMatch(tok, ") {"))
|
||||||
tok = tok->next()->link();
|
tok = tok->next()->link();
|
||||||
}
|
}
|
||||||
|
@ -3731,7 +3731,7 @@ void Tokenizer::setVarId()
|
||||||
// Found a class function..
|
// Found a class function..
|
||||||
if (Token::Match(tok2, funcpattern.c_str())) {
|
if (Token::Match(tok2, funcpattern.c_str())) {
|
||||||
// Goto the end parenthesis..
|
// Goto the end parenthesis..
|
||||||
tok2 = tok2->tokAt(3)->link();
|
tok2 = tok2->linkAt(3);
|
||||||
if (!tok2)
|
if (!tok2)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -3983,7 +3983,7 @@ void Tokenizer::simplifySizeof()
|
||||||
}
|
}
|
||||||
|
|
||||||
// sizeof * (...) -> sizeof(*...)
|
// sizeof * (...) -> sizeof(*...)
|
||||||
if (Token::simpleMatch(tok->next(), "* (") && !Token::simpleMatch(tok->tokAt(2)->link(), ") .")) {
|
if (Token::simpleMatch(tok->next(), "* (") && !Token::simpleMatch(tok->linkAt(2), ") .")) {
|
||||||
tok->deleteNext();
|
tok->deleteNext();
|
||||||
tok->next()->insertToken("*");
|
tok->next()->insertToken("*");
|
||||||
}
|
}
|
||||||
|
@ -4641,7 +4641,7 @@ bool Tokenizer::removeRedundantConditions()
|
||||||
const Token *elseTag = 0;
|
const Token *elseTag = 0;
|
||||||
|
|
||||||
// Find the closing "}"
|
// Find the closing "}"
|
||||||
elseTag = tok->tokAt(4)->link()->next();
|
elseTag = tok->linkAt(4)->next();
|
||||||
|
|
||||||
bool boolValue = false;
|
bool boolValue = false;
|
||||||
if (tok->strAt(2) == "true")
|
if (tok->strAt(2) == "true")
|
||||||
|
@ -4759,7 +4759,7 @@ void Tokenizer::removeRedundantFor()
|
||||||
bool read = false;
|
bool read = false;
|
||||||
bool write = false;
|
bool write = false;
|
||||||
unsigned int indentlevel = 0;
|
unsigned int indentlevel = 0;
|
||||||
for (const Token *tok2 = tok->tokAt(2)->link(); tok2; tok2 = tok2->next()) {
|
for (const Token *tok2 = tok->linkAt(2); tok2; tok2 = tok2->next()) {
|
||||||
if (tok2->str() == "{")
|
if (tok2->str() == "{")
|
||||||
++indentlevel;
|
++indentlevel;
|
||||||
else if (tok2->str() == "}") {
|
else if (tok2->str() == "}") {
|
||||||
|
@ -4894,7 +4894,7 @@ bool Tokenizer::simplifyIfAddBraces()
|
||||||
bool innerIf = Token::simpleMatch(tempToken->next(), "if");
|
bool innerIf = Token::simpleMatch(tempToken->next(), "if");
|
||||||
|
|
||||||
if (Token::simpleMatch(tempToken->next(), "do {"))
|
if (Token::simpleMatch(tempToken->next(), "do {"))
|
||||||
tempToken = tempToken->tokAt(2)->link();
|
tempToken = tempToken->linkAt(2);
|
||||||
|
|
||||||
// insert close brace..
|
// insert close brace..
|
||||||
// In most cases it would work to just search for the next ';' and insert a closing brace after it.
|
// In most cases it would work to just search for the next ';' and insert a closing brace after it.
|
||||||
|
@ -5421,7 +5421,7 @@ void Tokenizer::simplifyCasts()
|
||||||
// #2897 : don't remove cast in such cases:
|
// #2897 : don't remove cast in such cases:
|
||||||
// *((char *)a + 1) = 0;
|
// *((char *)a + 1) = 0;
|
||||||
if (!tok->isName() && Token::simpleMatch(tok->next(), "* (")) {
|
if (!tok->isName() && Token::simpleMatch(tok->next(), "* (")) {
|
||||||
tok = tok->tokAt(2)->link();
|
tok = tok->linkAt(2);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5619,13 +5619,13 @@ void Tokenizer:: simplifyFunctionPointers()
|
||||||
tok1 = tok1->next();
|
tok1 = tok1->next();
|
||||||
|
|
||||||
// check that the cast ends
|
// check that the cast ends
|
||||||
if (!Token::Match(tok1->tokAt(4)->link(), ") )|>"))
|
if (!Token::Match(tok1->linkAt(4), ") )|>"))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
// ok simplify this function pointer cast to an ordinary pointer cast
|
// ok simplify this function pointer cast to an ordinary pointer cast
|
||||||
tok1->deleteNext();
|
tok1->deleteNext();
|
||||||
tok1->next()->deleteNext();
|
tok1->next()->deleteNext();
|
||||||
const Token *tok2 = tok1->tokAt(2)->link();
|
const Token *tok2 = tok1->linkAt(2);
|
||||||
Token::eraseTokens(tok1->next(), tok2 ? tok2->next() : 0);
|
Token::eraseTokens(tok1->next(), tok2 ? tok2->next() : 0);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -5645,13 +5645,13 @@ void Tokenizer:: simplifyFunctionPointers()
|
||||||
tok = tok->next();
|
tok = tok->next();
|
||||||
|
|
||||||
// check that the declaration ends
|
// check that the declaration ends
|
||||||
if (!Token::Match(tok->tokAt(5)->link(), ") ;|,|)|=|["))
|
if (!Token::Match(tok->linkAt(5), ") ;|,|)|=|["))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
// ok simplify this function pointer to an ordinary pointer
|
// ok simplify this function pointer to an ordinary pointer
|
||||||
tok->deleteNext();
|
tok->deleteNext();
|
||||||
tok->tokAt(2)->deleteNext();
|
tok->tokAt(2)->deleteNext();
|
||||||
const Token *tok2 = tok->tokAt(3)->link();
|
const Token *tok2 = tok->linkAt(3);
|
||||||
Token::eraseTokens(tok->tokAt(2), tok2 ? tok2->next() : 0);
|
Token::eraseTokens(tok->tokAt(2), tok2 ? tok2->next() : 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -7245,7 +7245,7 @@ bool Tokenizer::simplifyRedundantParenthesis()
|
||||||
}
|
}
|
||||||
|
|
||||||
while (Token::Match(tok->previous(), "[,;{}(] ( %var% (") &&
|
while (Token::Match(tok->previous(), "[,;{}(] ( %var% (") &&
|
||||||
tok->link()->previous() == tok->tokAt(2)->link()) {
|
tok->link()->previous() == tok->linkAt(2)) {
|
||||||
// We have "( func ( *something* ))", remove the outer
|
// We have "( func ( *something* ))", remove the outer
|
||||||
// parenthesis
|
// parenthesis
|
||||||
tok->link()->deleteThis();
|
tok->link()->deleteThis();
|
||||||
|
@ -8622,10 +8622,10 @@ void Tokenizer::removeExceptionSpecifications(Token *tok) const
|
||||||
|
|
||||||
else if (Token::Match(tok, ") const| throw (")) {
|
else if (Token::Match(tok, ") const| throw (")) {
|
||||||
if (tok->next()->str() == "const") {
|
if (tok->next()->str() == "const") {
|
||||||
Token::eraseTokens(tok->next(), tok->tokAt(3)->link());
|
Token::eraseTokens(tok->next(), tok->linkAt(3));
|
||||||
tok = tok->next();
|
tok = tok->next();
|
||||||
} else
|
} else
|
||||||
Token::eraseTokens(tok, tok->tokAt(2)->link());
|
Token::eraseTokens(tok, tok->linkAt(2));
|
||||||
tok->deleteNext();
|
tok->deleteNext();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -8947,7 +8947,7 @@ void Tokenizer::simplifyFuncInWhile()
|
||||||
|
|
||||||
Token *func = tok->tokAt(2);
|
Token *func = tok->tokAt(2);
|
||||||
Token *var = tok->tokAt(4);
|
Token *var = tok->tokAt(4);
|
||||||
Token *end = tok->tokAt(7)->link();
|
Token *end = tok->linkAt(7);
|
||||||
if (!end)
|
if (!end)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -9176,7 +9176,7 @@ void Tokenizer::simplifyAssignmentInFunctionCall()
|
||||||
|
|
||||||
// Find 'foo(var='. Exclude 'assert(var=' to allow tests to check that assert(...) does not contain side-effects
|
// Find 'foo(var='. Exclude 'assert(var=' to allow tests to check that assert(...) does not contain side-effects
|
||||||
else if (Token::Match(tok, "[;{}] %var% ( %var% =") &&
|
else if (Token::Match(tok, "[;{}] %var% ( %var% =") &&
|
||||||
Token::simpleMatch(tok->tokAt(2)->link(), ") ;") &&
|
Token::simpleMatch(tok->linkAt(2), ") ;") &&
|
||||||
tok->next()->str() != "assert") {
|
tok->next()->str() != "assert") {
|
||||||
const std::string funcname(tok->next()->str());
|
const std::string funcname(tok->next()->str());
|
||||||
const Token * const vartok = tok->tokAt(3);
|
const Token * const vartok = tok->tokAt(3);
|
||||||
|
@ -9194,7 +9194,7 @@ void Tokenizer::simplifyAssignmentInFunctionCall()
|
||||||
tok2->next()->varId(vartok->varId());
|
tok2->next()->varId(vartok->varId());
|
||||||
|
|
||||||
tok2->insertToken("(");
|
tok2->insertToken("(");
|
||||||
Token::createMutualLinks(tok2->next(), tok->tokAt(2)->link());
|
Token::createMutualLinks(tok2->next(), tok->linkAt(2));
|
||||||
|
|
||||||
tok2->insertToken(funcname);
|
tok2->insertToken(funcname);
|
||||||
tok2->insertToken(";");
|
tok2->insertToken(";");
|
||||||
|
@ -9212,8 +9212,8 @@ void Tokenizer::simplifyAsm()
|
||||||
{
|
{
|
||||||
for (Token *tok = _tokens; tok; tok = tok->next()) {
|
for (Token *tok = _tokens; tok; tok = tok->next()) {
|
||||||
if (Token::Match(tok->next(), "__asm|_asm|asm {") &&
|
if (Token::Match(tok->next(), "__asm|_asm|asm {") &&
|
||||||
tok->tokAt(2)->link()->next()) {
|
tok->linkAt(2)->next()) {
|
||||||
Token::eraseTokens(tok, tok->tokAt(2)->link()->next());
|
Token::eraseTokens(tok, tok->linkAt(2)->next());
|
||||||
}
|
}
|
||||||
|
|
||||||
else if (Token::Match(tok->next(), "asm|__asm|__asm__ volatile|__volatile__| (")) {
|
else if (Token::Match(tok->next(), "asm|__asm|__asm__ volatile|__volatile__| (")) {
|
||||||
|
@ -9314,7 +9314,7 @@ void Tokenizer::simplifyBuiltinExpect()
|
||||||
}
|
}
|
||||||
} else if (Token::Match(tok->next(), "likely|unlikely (")) {
|
} else if (Token::Match(tok->next(), "likely|unlikely (")) {
|
||||||
// remove closing ')'
|
// remove closing ')'
|
||||||
tok->tokAt(2)->link()->previous()->deleteNext();
|
tok->linkAt(2)->previous()->deleteNext();
|
||||||
|
|
||||||
// remove "likely|unlikely ("
|
// remove "likely|unlikely ("
|
||||||
tok->deleteNext();
|
tok->deleteNext();
|
||||||
|
@ -9582,7 +9582,7 @@ void Tokenizer::simplifyQtSignalsSlots()
|
||||||
for (Token *tok = _tokens; tok; tok = tok->next()) {
|
for (Token *tok = _tokens; tok; tok = tok->next()) {
|
||||||
// check for emit which can be outside of class
|
// check for emit which can be outside of class
|
||||||
if (Token::Match(tok, "emit|Q_EMIT %var% (") &&
|
if (Token::Match(tok, "emit|Q_EMIT %var% (") &&
|
||||||
Token::simpleMatch(tok->tokAt(2)->link(), ") ;")) {
|
Token::simpleMatch(tok->linkAt(2), ") ;")) {
|
||||||
tok->deleteThis();
|
tok->deleteThis();
|
||||||
} else if (!Token::Match(tok, "class %var% :"))
|
} else if (!Token::Match(tok, "class %var% :"))
|
||||||
continue;
|
continue;
|
||||||
|
@ -9620,7 +9620,7 @@ void Tokenizer::simplifyQtSignalsSlots()
|
||||||
tok2->str("protected:");
|
tok2->str("protected:");
|
||||||
tok2->deleteNext();
|
tok2->deleteNext();
|
||||||
} else if (Token::Match(tok2->next(), "emit|Q_EMIT %var% (") &&
|
} else if (Token::Match(tok2->next(), "emit|Q_EMIT %var% (") &&
|
||||||
Token::simpleMatch(tok2->tokAt(3)->link(), ") ;")) {
|
Token::simpleMatch(tok2->linkAt(3), ") ;")) {
|
||||||
tok2->deleteNext();
|
tok2->deleteNext();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -9734,7 +9734,7 @@ void Tokenizer::removeUnnecessaryQualification()
|
||||||
} else if (tok->strAt(2) == "~")
|
} else if (tok->strAt(2) == "~")
|
||||||
++offset;
|
++offset;
|
||||||
|
|
||||||
if (tok->tokAt(offset) && Token::Match(tok->tokAt(offset)->link(), ") const| {|;|:")) {
|
if (tok->tokAt(offset) && Token::Match(tok->linkAt(offset), ") const| {|;|:")) {
|
||||||
std::string qualification = tok->str() + "::";
|
std::string qualification = tok->str() + "::";
|
||||||
|
|
||||||
// check for extra qualification
|
// check for extra qualification
|
||||||
|
|
|
@ -4677,16 +4677,16 @@ private:
|
||||||
tokenizer.tokenize(istr, "test.cpp");
|
tokenizer.tokenize(istr, "test.cpp");
|
||||||
const Token *tok = tokenizer.tokens();
|
const Token *tok = tokenizer.tokens();
|
||||||
// A body {}
|
// A body {}
|
||||||
ASSERT_EQUALS(true, tok->tokAt(2)->link() == tok->tokAt(9));
|
ASSERT_EQUALS(true, tok->linkAt(2) == tok->tokAt(9));
|
||||||
ASSERT_EQUALS(true, tok->tokAt(9)->link() == tok->tokAt(2));
|
ASSERT_EQUALS(true, tok->linkAt(9) == tok->tokAt(2));
|
||||||
|
|
||||||
// f body {}
|
// f body {}
|
||||||
ASSERT_EQUALS(true, tok->tokAt(7)->link() == tok->tokAt(8));
|
ASSERT_EQUALS(true, tok->linkAt(7) == tok->tokAt(8));
|
||||||
ASSERT_EQUALS(true, tok->tokAt(8)->link() == tok->tokAt(7));
|
ASSERT_EQUALS(true, tok->linkAt(8) == tok->tokAt(7));
|
||||||
|
|
||||||
// f ()
|
// f ()
|
||||||
ASSERT_EQUALS(true, tok->tokAt(5)->link() == tok->tokAt(6));
|
ASSERT_EQUALS(true, tok->linkAt(5) == tok->tokAt(6));
|
||||||
ASSERT_EQUALS(true, tok->tokAt(6)->link() == tok->tokAt(5));
|
ASSERT_EQUALS(true, tok->linkAt(6) == tok->tokAt(5));
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
|
@ -4701,16 +4701,16 @@ private:
|
||||||
tokenizer.tokenize(istr, "test.cpp");
|
tokenizer.tokenize(istr, "test.cpp");
|
||||||
const Token *tok = tokenizer.tokens();
|
const Token *tok = tokenizer.tokens();
|
||||||
// a[10]
|
// a[10]
|
||||||
ASSERT_EQUALS(true, tok->tokAt(7)->link() == tok->tokAt(9));
|
ASSERT_EQUALS(true, tok->linkAt(7) == tok->tokAt(9));
|
||||||
ASSERT_EQUALS(true, tok->tokAt(9)->link() == tok->tokAt(7));
|
ASSERT_EQUALS(true, tok->linkAt(9) == tok->tokAt(7));
|
||||||
|
|
||||||
// new char[]
|
// new char[]
|
||||||
ASSERT_EQUALS(true, tok->tokAt(19)->link() == tok->tokAt(24));
|
ASSERT_EQUALS(true, tok->linkAt(19) == tok->tokAt(24));
|
||||||
ASSERT_EQUALS(true, tok->tokAt(24)->link() == tok->tokAt(19));
|
ASSERT_EQUALS(true, tok->linkAt(24) == tok->tokAt(19));
|
||||||
|
|
||||||
// a[0]
|
// a[0]
|
||||||
ASSERT_EQUALS(true, tok->tokAt(21)->link() == tok->tokAt(23));
|
ASSERT_EQUALS(true, tok->linkAt(21) == tok->tokAt(23));
|
||||||
ASSERT_EQUALS(true, tok->tokAt(23)->link() == tok->tokAt(21));
|
ASSERT_EQUALS(true, tok->linkAt(23) == tok->tokAt(21));
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
|
@ -4724,12 +4724,12 @@ private:
|
||||||
tokenizer.tokenize(istr, "test.cpp");
|
tokenizer.tokenize(istr, "test.cpp");
|
||||||
const Token *tok = tokenizer.tokens();
|
const Token *tok = tokenizer.tokens();
|
||||||
// foo(
|
// foo(
|
||||||
ASSERT_EQUALS(true, tok->tokAt(6)->link() == tok->tokAt(10));
|
ASSERT_EQUALS(true, tok->linkAt(6) == tok->tokAt(10));
|
||||||
ASSERT_EQUALS(true, tok->tokAt(10)->link() == tok->tokAt(6));
|
ASSERT_EQUALS(true, tok->linkAt(10) == tok->tokAt(6));
|
||||||
|
|
||||||
// g(
|
// g(
|
||||||
ASSERT_EQUALS(true, tok->tokAt(8)->link() == tok->tokAt(9));
|
ASSERT_EQUALS(true, tok->linkAt(8) == tok->tokAt(9));
|
||||||
ASSERT_EQUALS(true, tok->tokAt(9)->link() == tok->tokAt(8));
|
ASSERT_EQUALS(true, tok->linkAt(9) == tok->tokAt(8));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue