Tokenizer: Change 'var++|--;' into '++|--var;' and remove redundant 'tokAt(0)'.

This commit is contained in:
Edoardo Prezioso 2011-10-29 20:36:44 +02:00
parent 92333b585a
commit 42fd4e2f52
1 changed files with 82 additions and 80 deletions

View File

@ -329,7 +329,7 @@ void Tokenizer::createTokens(std::istream &code)
++lineno; ++lineno;
bool foundOurfile = false; bool foundOurfile = false;
fileIndexes.push_back(FileIndex); fileIndexes.push_back(FileIndex);
for (unsigned int i = 0; i < _files.size(); i++) { for (unsigned int i = 0; i < _files.size(); ++i) {
if (Path::sameFileName(_files[i].c_str(), line.c_str())) { if (Path::sameFileName(_files[i].c_str(), line.c_str())) {
// Use this index // Use this index
foundOurfile = true; foundOurfile = true;
@ -523,9 +523,9 @@ bool Tokenizer::duplicateTypedef(Token **tokPtr, const Token *name, const Token
while (end && end->next() && (!Token::Match(end->next(), ";|)|>") || while (end && end->next() && (!Token::Match(end->next(), ";|)|>") ||
(end->next()->str() == ")" && level == 0))) { (end->next()->str() == ")" && level == 0))) {
if (end->next()->str() == "(") if (end->next()->str() == "(")
level++; ++level;
else if (end->next()->str() == ")") else if (end->next()->str() == ")")
level--; --level;
end = end->next(); end = end->next();
} }
@ -641,7 +641,7 @@ bool Tokenizer::duplicateTypedef(Token **tokPtr, const Token *name, const Token
return false; return false;
} }
} else if (tok->previous()->str() == "{") } else if (tok->previous()->str() == "{")
level--; --level;
tok = tok->previous(); tok = tok->previous();
} }
@ -663,14 +663,17 @@ void Tokenizer::unsupportedTypedef(const Token *tok) const
std::ostringstream str; std::ostringstream str;
const Token *tok1 = tok; const Token *tok1 = tok;
int level = 0; unsigned int level = 0;
while (tok) { while (tok) {
if (level == 0 && tok->str() == ";") if (level == 0 && tok->str() == ";")
break; break;
else if (tok->str() == "{") else if (tok->str() == "{")
level++; ++level;
else if (tok->str() == "}") else if (tok->str() == "}") {
level--; if (!level)
break;
--level;
}
if (tok != tok1) if (tok != tok1)
str << " "; str << " ";
@ -700,16 +703,19 @@ void Tokenizer::unsupportedTypedef(const Token *tok) const
Token * Tokenizer::deleteInvalidTypedef(Token *typeDef) Token * Tokenizer::deleteInvalidTypedef(Token *typeDef)
{ {
Token *tok = NULL; Token *tok = NULL;
int level = 0; unsigned int level = 0;
// remove typedef but leave ; // remove typedef but leave ;
while (typeDef->next()) { while (typeDef->next()) {
if (level == 0 && typeDef->next()->str() == ";") if (level == 0 && typeDef->next()->str() == ";")
break; break;
else if (typeDef->next()->str() == "{") else if (typeDef->next()->str() == "{")
level++; ++level;
else if (typeDef->next()->str() == "}") else if (typeDef->next()->str() == "}") {
level--; if (!level)
break;
--level;
}
typeDef->deleteNext(); typeDef->deleteNext();
} }
@ -749,8 +755,8 @@ static Token *splitDefinitionFromTypedef(Token *tok)
if (Token::Match(tok1->next(), "%type%")) if (Token::Match(tok1->next(), "%type%"))
name = tok1->next()->str(); name = tok1->next()->str();
else { // create a unique name else { // create a unique name
static long count = 0; static unsigned int count = 0;
name = "Unnamed" + MathLib::toString<long>(count++); name = "Unnamed" + MathLib::toString<unsigned int>(count++);
} }
tok->next()->insertToken(name.c_str()); tok->next()->insertToken(name.c_str());
} else } else
@ -950,7 +956,7 @@ void Tokenizer::simplifyTypedef()
Token *argFuncRetEnd = 0; Token *argFuncRetEnd = 0;
Token *funcStart = 0; Token *funcStart = 0;
Token *funcEnd = 0; Token *funcEnd = 0;
int offset = 1; unsigned int offset = 1;
bool function = false; bool function = false;
bool functionPtr = false; bool functionPtr = false;
bool functionRef = false; bool functionRef = false;
@ -976,7 +982,7 @@ void Tokenizer::simplifyTypedef()
while (Token::Match(tok->tokAt(offset), "const|signed|unsigned|struct|enum %type%") || while (Token::Match(tok->tokAt(offset), "const|signed|unsigned|struct|enum %type%") ||
(tok->tokAt(offset + 1) && tok->tokAt(offset + 1)->isStandardType())) (tok->tokAt(offset + 1) && tok->tokAt(offset + 1)->isStandardType()))
offset++; ++offset;
typeEnd = tok->tokAt(offset++); typeEnd = tok->tokAt(offset++);
@ -1005,23 +1011,26 @@ void Tokenizer::simplifyTypedef()
// check for template // check for template
if (tok->tokAt(offset)->str() == "<") { if (tok->tokAt(offset)->str() == "<") {
int level = 1; unsigned int level = 0;
int paren = 0; unsigned int paren = 0;
typeEnd = tok->tokAt(offset + 1); typeEnd = tok->tokAt(offset + 1);
for (; typeEnd ; typeEnd = typeEnd->next()) { for (; typeEnd ; typeEnd = typeEnd->next()) {
if (typeEnd->str() == ">") { if (typeEnd->str() == ">") {
if (paren == 0) { if (!paren) {
level--; if (!level)
if (level == 0)
break; break;
--level;
} }
} else if (typeEnd->str() == "<") { } else if (typeEnd->str() == "<") {
if (paren == 0) if (!paren)
level++; ++level;
} else if (typeEnd->str() == "(") } else if (typeEnd->str() == "(")
paren++; ++paren;
else if (typeEnd->str() == ")") else if (typeEnd->str() == ")") {
paren--; if (!paren)
break;
--paren;
}
} }
while (typeEnd && Token::Match(typeEnd->next(), ":: %type%")) while (typeEnd && Token::Match(typeEnd->next(), ":: %type%"))
@ -1060,7 +1069,7 @@ void Tokenizer::simplifyTypedef()
bool atEnd = false; bool atEnd = false;
while (!atEnd) { while (!atEnd) {
while (tok->tokAt(offset + 1) && !Token::Match(tok->tokAt(offset + 1), ";|,")) while (tok->tokAt(offset + 1) && !Token::Match(tok->tokAt(offset + 1), ";|,"))
offset++; ++offset;
if (!tok->tokAt(offset + 1)) if (!tok->tokAt(offset + 1))
return; // invalid input return; // invalid input
@ -1069,7 +1078,7 @@ void Tokenizer::simplifyTypedef()
else if (tok->tokAt(offset)->str() == "]") else if (tok->tokAt(offset)->str() == "]")
atEnd = true; atEnd = true;
else else
offset++; ++offset;
} }
arrayEnd = tok->tokAt(offset++); arrayEnd = tok->tokAt(offset++);
@ -1153,7 +1162,7 @@ void Tokenizer::simplifyTypedef()
Token::Match(tok->tokAt(offset + 2)->link()->previous(), "%type% ) (") && Token::Match(tok->tokAt(offset + 2)->link()->previous(), "%type% ) (") &&
Token::Match(tok->tokAt(offset + 2)->link()->next()->link(), ") const|volatile| ) ;|,"))) { Token::Match(tok->tokAt(offset + 2)->link()->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), "( * (")) {
pointers.push_back("*"); pointers.push_back("*");
offset += 2; offset += 2;
@ -1285,7 +1294,7 @@ void Tokenizer::simplifyTypedef()
if (tok2->str() == "}") { if (tok2->str() == "}") {
// check for end of member function // check for end of member function
if (inMemberFunc) { if (inMemberFunc) {
memberScope--; --memberScope;
if (memberScope == 0) if (memberScope == 0)
inMemberFunc = false; inMemberFunc = false;
} }
@ -1294,12 +1303,12 @@ void Tokenizer::simplifyTypedef()
--classLevel; --classLevel;
pattern.clear(); pattern.clear();
for (std::size_t i = classLevel; i < spaceInfo.size(); i++) for (std::size_t i = classLevel; i < spaceInfo.size(); ++i)
pattern += (spaceInfo[i].className + " :: "); pattern += (spaceInfo[i].className + " :: ");
pattern += typeName->str(); pattern += typeName->str();
} else { } else {
scope--; --scope;
if (scope < 0) if (scope < 0)
inScope = false; inScope = false;
@ -1351,23 +1360,23 @@ void Tokenizer::simplifyTypedef()
if (classLevel < spaceInfo.size() && if (classLevel < spaceInfo.size() &&
spaceInfo[classLevel].isNamespace && spaceInfo[classLevel].isNamespace &&
spaceInfo[classLevel].className == tok2->next()->str()) { spaceInfo[classLevel].className == tok2->next()->str()) {
classLevel++; ++classLevel;
pattern.clear(); pattern.clear();
for (std::size_t i = classLevel; i < spaceInfo.size(); i++) for (std::size_t i = classLevel; i < spaceInfo.size(); ++i)
pattern += (spaceInfo[i].className + " :: "); pattern += (spaceInfo[i].className + " :: ");
pattern += typeName->str(); pattern += typeName->str();
} }
scope++; ++scope;
} }
// check for entering a new scope // check for entering a new scope
else if (tok2->str() == "{") { else if (tok2->str() == "{") {
// keep track of scopes within member function // keep track of scopes within member function
if (inMemberFunc) if (inMemberFunc)
memberScope++; ++memberScope;
scope++; ++scope;
} }
// check for typedef that can be substituted // check for typedef that can be substituted
@ -1387,7 +1396,7 @@ void Tokenizer::simplifyTypedef()
globalScope = true; globalScope = true;
} }
for (std::size_t i = classLevel; i < spaceInfo.size(); i++) { for (std::size_t i = classLevel; i < spaceInfo.size(); ++i) {
tok2->deleteNext(); tok2->deleteNext();
tok2->deleteNext(); tok2->deleteNext();
} }
@ -1412,9 +1421,9 @@ void Tokenizer::simplifyTypedef()
int level = 0; int level = 0;
while (tok2->next() && (tok2->next()->str() != "}" || level)) { while (tok2->next() && (tok2->next()->str() != "}" || level)) {
if (tok2->next()->str() == "{") if (tok2->next()->str() == "{")
level++; ++level;
else if (tok2->next()->str() == "}") else if (tok2->next()->str() == "}")
level--; --level;
tok2 = tok2->next(); tok2 = tok2->next();
} }
@ -1490,7 +1499,7 @@ void Tokenizer::simplifyTypedef()
tok2 = tok2->next(); tok2 = tok2->next();
} }
for (std::size_t i = classLevel; i < spaceInfo.size(); i++) { for (std::size_t i = classLevel; i < spaceInfo.size(); ++i) {
tok2->insertToken(spaceInfo[i].className); tok2->insertToken(spaceInfo[i].className);
tok2 = tok2->next(); tok2 = tok2->next();
tok2->insertToken("::"); tok2->insertToken("::");
@ -1753,7 +1762,7 @@ void Tokenizer::simplifyTypedef()
bool atEnd = false; bool atEnd = false;
while (!atEnd) { while (!atEnd) {
while (tok->tokAt(offset + 1) && !Token::Match(tok->tokAt(offset + 1), ";|,")) while (tok->tokAt(offset + 1) && !Token::Match(tok->tokAt(offset + 1), ";|,"))
offset++; ++offset;
if (!tok->tokAt(offset + 1)) if (!tok->tokAt(offset + 1))
return; // invalid input return; // invalid input
@ -1762,7 +1771,7 @@ void Tokenizer::simplifyTypedef()
else if (tok->tokAt(offset)->str() == "]") else if (tok->tokAt(offset)->str() == "]")
atEnd = true; atEnd = true;
else else
offset++; ++offset;
} }
arrayEnd = tok->tokAt(offset++); arrayEnd = tok->tokAt(offset++);
@ -2494,7 +2503,7 @@ void Tokenizer::arraySize()
while (Token::Match(tok2, "%any% ,")) { while (Token::Match(tok2, "%any% ,")) {
if (tok2->isName()) if (tok2->isName())
break; break;
sz++; ++sz;
tok2 = tok2->tokAt(2); tok2 = tok2->tokAt(2);
} }
@ -2965,7 +2974,7 @@ void Tokenizer::simplifyTemplatesInstantiate(const Token *tok,
if (sz1 != used.size()) { if (sz1 != used.size()) {
sz1 = used.size(); sz1 = used.size();
simplifyCalculations(); simplifyCalculations();
recursiveCount++; ++recursiveCount;
if (recursiveCount > 100) { if (recursiveCount > 100) {
// bail out.. // bail out..
break; break;
@ -3405,7 +3414,7 @@ void Tokenizer::setVarId()
tok2 = tok2->tokAt(2); tok2 = tok2->tokAt(2);
if (Token::Match(tok2, "%type% <")) { if (Token::Match(tok2, "%type% <")) {
level++; ++level;
tok2 = tok2->tokAt(2); tok2 = tok2->tokAt(2);
again = true; again = true;
} else if (Token::Match(tok2, "%type% *|&| ,")) { } else if (Token::Match(tok2, "%type% *|&| ,")) {
@ -3452,7 +3461,7 @@ void Tokenizer::setVarId()
if (level == 1 && Token::Match(tok2, "> %var%")) if (level == 1 && Token::Match(tok2, "> %var%"))
tok = tok2; tok = tok2;
else if (level > 1 && tok2 && tok2->str() == ">") { else if (level > 1 && tok2 && tok2->str() == ">") {
level--; --level;
if (level == 0) if (level == 0)
tok = tok2; tok = tok2;
else { else {
@ -5659,7 +5668,7 @@ void Tokenizer::simplifyVarDecl()
// check for qualification.. // check for qualification..
if (Token::Match(tok2, ":: %type%")) { if (Token::Match(tok2, ":: %type%")) {
typelen++; ++typelen;
tok2 = tok2->next(); tok2 = tok2->next();
} }
@ -5768,7 +5777,7 @@ void Tokenizer::simplifyVarDecl()
if (Token::Match(tok2, "%var% ,|=")) { if (Token::Match(tok2, "%var% ,|=")) {
tok2 = tok2->next(); // The ',' token tok2 = tok2->next(); // The ',' token
typelen--; --typelen;
} else { } else {
tok2 = NULL; tok2 = NULL;
typelen = 0; typelen = 0;
@ -7724,9 +7733,9 @@ bool Tokenizer::duplicateDefinition(Token ** tokPtr, const Token * name)
while (end && end->next() && (!Token::Match(end->next(), ";|)|>") || while (end && end->next() && (!Token::Match(end->next(), ";|)|>") ||
(end->next()->str() == ")" && level == 0))) { (end->next()->str() == ")" && level == 0))) {
if (end->next()->str() == "(") if (end->next()->str() == "(")
level++; ++level;
else if (end->next()->str() == ")") else if (end->next()->str() == ")")
level--; --level;
end = end->next(); end = end->next();
} }
@ -7886,7 +7895,7 @@ void Tokenizer::simplifyEnum()
if (Token::Match(tok1->previous(), ",|{ %type% ,|}")) { if (Token::Match(tok1->previous(), ",|{ %type% ,|}")) {
// no value specified // no value specified
enumName = tok1; enumName = tok1;
lastValue++; ++lastValue;
tok1->insertToken("="); tok1->insertToken("=");
tok1 = tok1->next(); tok1 = tok1->next();
@ -7925,17 +7934,17 @@ void Tokenizer::simplifyEnum()
if (enumValueEnd->str() == "(" || if (enumValueEnd->str() == "(" ||
enumValueEnd->str() == "[" || enumValueEnd->str() == "[" ||
enumValueEnd->str() == "{") enumValueEnd->str() == "{")
level++; ++level;
while (enumValueEnd->next() && while (enumValueEnd->next() &&
(!Token::Match(enumValueEnd->next(), "}|,") || level)) { (!Token::Match(enumValueEnd->next(), "}|,") || level)) {
if (enumValueEnd->next()->str() == "(" || if (enumValueEnd->next()->str() == "(" ||
enumValueEnd->next()->str() == "[" || enumValueEnd->next()->str() == "[" ||
enumValueEnd->next()->str() == "{") enumValueEnd->next()->str() == "{")
level++; ++level;
else if (enumValueEnd->next()->str() == ")" || else if (enumValueEnd->next()->str() == ")" ||
enumValueEnd->next()->str() == "]" || enumValueEnd->next()->str() == "]" ||
enumValueEnd->next()->str() == "}") enumValueEnd->next()->str() == "}")
level--; --level;
enumValueEnd = enumValueEnd->next(); enumValueEnd = enumValueEnd->next();
} }
@ -8582,7 +8591,7 @@ std::string Tokenizer::simplifyString(const std::string &source)
// true when previous char is a \ . // true when previous char is a \ .
bool escaped = false; bool escaped = false;
for (std::string::size_type i = 0; i + 2 < str.size(); i++) { for (std::string::size_type i = 0; i + 2 < str.size(); ++i) {
if (!escaped) { if (!escaped) {
if (str[i] == '\\') if (str[i] == '\\')
escaped = true; escaped = true;
@ -9083,7 +9092,6 @@ 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() &&
tok->tokAt(2)->link()->next()) { tok->tokAt(2)->link()->next()) {
Token::eraseTokens(tok, tok->tokAt(2)->link()->next()); Token::eraseTokens(tok, tok->tokAt(2)->link()->next());
} }
@ -9127,11 +9135,7 @@ void Tokenizer::simplifyBitfields()
if (Token::Match(tok, ";|{|}|public:|protected:|private: const| %type% %var% :") && if (Token::Match(tok, ";|{|}|public:|protected:|private: const| %type% %var% :") &&
!Token::Match(tok->next(), "case|public|protected|private|class|struct") && !Token::Match(tok->next(), "case|public|protected|private|class|struct") &&
!Token::simpleMatch(tok->tokAt(2), "default :")) { !Token::simpleMatch(tok->tokAt(2), "default :")) {
int offset = 0; Token *tok1 = (tok->next()->str() == "const") ? tok->tokAt(3) : tok->tokAt(2);
if (tok->next()->str() == "const")
offset = 1;
Token *tok1 = tok->tokAt(2 + offset);
if (tok1 && tok1->tokAt(2) && if (tok1 && tok1->tokAt(2) &&
(tok1->tokAt(2)->isBoolean() || Token::Match(tok1->tokAt(2), "%num%") || (tok1->tokAt(2)->isBoolean() || Token::Match(tok1->tokAt(2), "%num%") ||
!Token::Match(tok1->tokAt(2), "public|protected|private| %type% ::|<|,|{|;"))) { !Token::Match(tok1->tokAt(2), "public|protected|private| %type% ::|<|,|{|;"))) {
@ -9142,12 +9146,10 @@ void Tokenizer::simplifyBitfields()
} }
} else if (Token::Match(tok, ";|{|}|public:|protected:|private: const| %type% : %any% ;") && } else if (Token::Match(tok, ";|{|}|public:|protected:|private: const| %type% : %any% ;") &&
tok->next()->str() != "default") { tok->next()->str() != "default") {
int offset = 0; unsigned char offset = (tok->next()->str() == "const");
if (tok->next()->str() == "const")
offset = 1;
if (tok->strAt(3 + offset) != "{") { if (tok->strAt(3 + offset) != "{") {
Token::eraseTokens(tok->tokAt(0), tok->tokAt(5 + offset)); Token::eraseTokens(tok, tok->tokAt(5 + offset));
tok = tok->previous(); tok = tok->previous();
} }
} }
@ -9247,9 +9249,9 @@ void Tokenizer::simplifyMicrosoftMemoryFunctions()
unsigned int level = 0; unsigned int level = 0;
while (tok1) { while (tok1) {
if (tok1->str() == "(") if (tok1->str() == "(")
level++; ++level;
else if (tok1->str() == ")") else if (tok1->str() == ")")
level--; --level;
else if (level == 0 && tok1->str() == ",") else if (level == 0 && tok1->str() == ",")
break; break;
@ -9262,9 +9264,9 @@ void Tokenizer::simplifyMicrosoftMemoryFunctions()
level = 0; level = 0;
while (tok2) { while (tok2) {
if (tok2->str() == "(") if (tok2->str() == "(")
level++; ++level;
else if (tok2->str() == ")") else if (tok2->str() == ")")
level--; --level;
else if (level == 0 && tok2->str() == ",") else if (level == 0 && tok2->str() == ",")
break; break;
@ -9284,9 +9286,9 @@ void Tokenizer::simplifyMicrosoftMemoryFunctions()
unsigned int level = 0; unsigned int level = 0;
while (tok1) { while (tok1) {
if (tok1->str() == "(") if (tok1->str() == "(")
level++; ++level;
else if (tok1->str() == ")") else if (tok1->str() == ")")
level--; --level;
else if (level == 0 && tok1->str() == ",") else if (level == 0 && tok1->str() == ",")
break; break;
@ -9474,13 +9476,13 @@ void Tokenizer::simplifyQtSignalsSlots()
unsigned int indentlevel = 0; unsigned int indentlevel = 0;
for (Token *tok2 = tok; tok2; tok2 = tok2->next()) { for (Token *tok2 = tok; tok2; tok2 = tok2->next()) {
if (tok2->str() == "{") { if (tok2->str() == "{") {
indentlevel++; ++indentlevel;
if (indentlevel == 1) if (indentlevel == 1)
tok = tok2; tok = tok2;
else else
tok2 = tok2->link(); tok2 = tok2->link();
} else if (tok2->str() == "}") { } else if (tok2->str() == "}") {
indentlevel--; --indentlevel;
if (indentlevel == 0) if (indentlevel == 0)
break; break;
} }
@ -9598,15 +9600,15 @@ void Tokenizer::removeUnnecessaryQualification()
// check for operator () // check for operator ()
if (tok1->str() == "(") { if (tok1->str() == "(") {
tok1 = tok1->next(); tok1 = tok1->next();
offset++; ++offset;
} }
while (tok1 && tok1->str() != "(") { while (tok1 && tok1->str() != "(") {
tok1 = tok1->next(); tok1 = tok1->next();
offset++; ++offset;
} }
} else if (tok->strAt(2) == "~") } else if (tok->strAt(2) == "~")
offset++; ++offset;
if (Token::Match(tok->tokAt(offset)->link(), ") const| {|;|:")) { if (Token::Match(tok->tokAt(offset)->link(), ") const| {|;|:")) {
std::string qualification = tok->str() + "::"; std::string qualification = tok->str() + "::";
@ -9678,7 +9680,7 @@ void Tokenizer::printUnknownTypes()
std::set<std::string> unknowns; std::set<std::string> unknowns;
for (size_t i = 1; i <= _varId; i++) { for (size_t i = 1; i <= _varId; ++i) {
const Variable *var = _symbolDatabase->getVariableFromVarId(i); const Variable *var = _symbolDatabase->getVariableFromVarId(i);
// is unknown record type? // is unknown record type?
@ -9706,9 +9708,9 @@ void Tokenizer::printUnknownTypes()
// pointers and referennces are OK in template // pointers and referennces are OK in template
else if (tok->str() == "<") else if (tok->str() == "<")
level++; ++level;
else if (tok->str() == ">") else if (tok->str() == ">")
level--; --level;
if (tok == var->typeEndToken()) if (tok == var->typeEndToken())
break; break;