Merge pull request #442 from Dmitry-Me/removeComparisonDuplication
Move variable declarations, remove unneeded assignments, remove comparis...
This commit is contained in:
commit
2068b91fbf
|
@ -1541,8 +1541,9 @@ void SymbolDatabase::addClassFunction(Scope **scope, const Token **tok, const To
|
||||||
} else if (func->type != Function::eDestructor && !destructor) {
|
} else if (func->type != Function::eDestructor && !destructor) {
|
||||||
// normal function?
|
// normal function?
|
||||||
if ((*tok)->next()->link()) {
|
if ((*tok)->next()->link()) {
|
||||||
if ((func->isConst && (*tok)->next()->link()->next()->str() == "const") ||
|
const bool hasConstKeyword = (*tok)->next()->link()->next()->str() == "const";
|
||||||
(!func->isConst && (*tok)->next()->link()->next()->str() != "const")) {
|
if ((func->isConst && hasConstKeyword) ||
|
||||||
|
(!func->isConst && !hasConstKeyword)) {
|
||||||
func->hasBody = true;
|
func->hasBody = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1620,16 +1621,14 @@ const Token *Type::initBaseInfo(const Token *tok, const Token *tok1)
|
||||||
|
|
||||||
// check for base classes
|
// check for base classes
|
||||||
else if (Token::Match(tok2, ":|,")) {
|
else if (Token::Match(tok2, ":|,")) {
|
||||||
Type::BaseInfo base;
|
|
||||||
|
|
||||||
base.isVirtual = false;
|
|
||||||
|
|
||||||
tok2 = tok2->next();
|
tok2 = tok2->next();
|
||||||
|
|
||||||
// check for invalid code
|
// check for invalid code
|
||||||
if (!tok2 || !tok2->next())
|
if (!tok2 || !tok2->next())
|
||||||
return nullptr;
|
return nullptr;
|
||||||
|
|
||||||
|
Type::BaseInfo base;
|
||||||
|
|
||||||
if (tok2->str() == "virtual") {
|
if (tok2->str() == "virtual") {
|
||||||
base.isVirtual = true;
|
base.isVirtual = true;
|
||||||
tok2 = tok2->next();
|
tok2 = tok2->next();
|
||||||
|
@ -1669,7 +1668,6 @@ const Token *Type::initBaseInfo(const Token *tok, const Token *tok1)
|
||||||
}
|
}
|
||||||
|
|
||||||
base.name = tok2->str();
|
base.name = tok2->str();
|
||||||
base.type = nullptr;
|
|
||||||
|
|
||||||
// add unhandled templates
|
// add unhandled templates
|
||||||
if (tok2->next() && tok2->next()->str() == "<") {
|
if (tok2->next() && tok2->next()->str() == "<") {
|
||||||
|
@ -2188,13 +2186,13 @@ void Function::addArguments(const SymbolDatabase *symbolDatabase, const Scope *s
|
||||||
unsigned int count = 0;
|
unsigned int count = 0;
|
||||||
|
|
||||||
for (const Token* tok = start->next(); tok; tok = tok->next()) {
|
for (const Token* tok = start->next(); tok; tok = tok->next()) {
|
||||||
|
if (Token::Match(tok, ",|)"))
|
||||||
|
return; // Syntax error
|
||||||
|
|
||||||
const Token* startTok = tok;
|
const Token* startTok = tok;
|
||||||
const Token* endTok = nullptr;
|
const Token* endTok = nullptr;
|
||||||
const Token* nameTok = nullptr;
|
const Token* nameTok = nullptr;
|
||||||
|
|
||||||
if (Token::Match(tok, ",|)"))
|
|
||||||
return; // Syntax error
|
|
||||||
|
|
||||||
do {
|
do {
|
||||||
if (tok->varId() != 0) {
|
if (tok->varId() != 0) {
|
||||||
nameTok = tok;
|
nameTok = tok;
|
||||||
|
@ -2572,10 +2570,6 @@ void Scope::getVariableList()
|
||||||
|
|
||||||
const Token *Scope::checkVariable(const Token *tok, AccessControl varaccess)
|
const Token *Scope::checkVariable(const Token *tok, AccessControl varaccess)
|
||||||
{
|
{
|
||||||
// This is the start of a statement
|
|
||||||
const Token *vartok = nullptr;
|
|
||||||
const Token *typetok = nullptr;
|
|
||||||
|
|
||||||
// Is it a throw..?
|
// Is it a throw..?
|
||||||
if (Token::Match(tok, "throw %any% (") &&
|
if (Token::Match(tok, "throw %any% (") &&
|
||||||
Token::simpleMatch(tok->linkAt(2), ") ;")) {
|
Token::simpleMatch(tok->linkAt(2), ") ;")) {
|
||||||
|
@ -2605,6 +2599,10 @@ const Token *Scope::checkVariable(const Token *tok, AccessControl varaccess)
|
||||||
tok = tok->next();
|
tok = tok->next();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// This is the start of a statement
|
||||||
|
const Token *vartok = nullptr;
|
||||||
|
const Token *typetok = nullptr;
|
||||||
|
|
||||||
if (tok && isVariableDeclaration(tok, vartok, typetok)) {
|
if (tok && isVariableDeclaration(tok, vartok, typetok)) {
|
||||||
// If the vartok was set in the if-blocks above, create a entry for this variable..
|
// If the vartok was set in the if-blocks above, create a entry for this variable..
|
||||||
tok = vartok->next();
|
tok = vartok->next();
|
||||||
|
|
Loading…
Reference in New Issue