Symboldatabase: improved look up of delegate constructors

This commit is contained in:
Robert Reif 2014-11-13 06:29:51 +01:00 committed by Daniel Marjamäki
parent 189dfd64f7
commit 67385cfc4b
2 changed files with 25 additions and 4 deletions

View File

@ -444,7 +444,7 @@ void CheckClass::initializeVarList(const Function &func, std::list<const Functio
if (ftok->str() != func.name()) { if (ftok->str() != func.name()) {
initVar(ftok->str(), scope, usage); initVar(ftok->str(), scope, usage);
} else { // c++11 delegate constructor } else { // c++11 delegate constructor
const Function *member = scope->findFunction(ftok); const Function *member = ftok->function();
// member function found // member function found
if (member) { if (member) {
// recursive call // recursive call

View File

@ -1125,6 +1125,27 @@ SymbolDatabase::SymbolDatabase(const Tokenizer *tokenizer, const Settings *setti
} }
} }
// Set C++ 11 delegate constructor function call pointers
for (std::list<Scope>::iterator it = scopeList.begin(); it != scopeList.end(); ++it) {
for (std::list<Function>::const_iterator func = it->functionList.begin(); func != it->functionList.end(); ++func) {
// look for initializer list
if (func->type == Function::eConstructor && func->functionScope &&
func->functionScope->functionOf && func->arg && func->arg->link()->strAt(1) == ":") {
const Token * tok = func->arg->link()->tokAt(2);
while (tok && tok != func->functionScope->classStart) {
if (Token::Match(tok, "%var% {")) {
if (tok->str() == func->tokenDef->str()) {
const_cast<Token *>(tok)->function(func->functionScope->functionOf->findFunction(tok));
break;
}
tok = tok->linkAt(1);
}
tok = tok->next();
}
}
}
}
// Set variable pointers // Set variable pointers
for (const Token* tok = _tokenizer->list.front(); tok != _tokenizer->list.back(); tok = tok->next()) { for (const Token* tok = _tokenizer->list.front(); tok != _tokenizer->list.back(); tok = tok->next()) {
if (tok->varId()) if (tok->varId())
@ -2926,12 +2947,12 @@ const Function* Scope::findFunction(const Token *tok) const
for (it = functionList.begin(); it != functionList.end(); ++it) { for (it = functionList.begin(); it != functionList.end(); ++it) {
if (it->tokenDef->str() == tok->str()) { if (it->tokenDef->str() == tok->str()) {
const Function *func = &*it; const Function *func = &*it;
if ((tok->strAt(1) == "(" || (func->name() == tok->str() && tok->strAt(1) == "{" && func->type == Function::eConstructor)) && tok->tokAt(2)) { const Token *end = tok->linkAt(1);
std::string end(tok->strAt(1) == "{" ? "}" : ")"); if (end) {
// check the arguments // check the arguments
unsigned int args = 0; unsigned int args = 0;
const Token *arg = tok->tokAt(2); const Token *arg = tok->tokAt(2);
while (arg && arg->str() != end) { while (arg && arg != end) {
/** @todo check argument type for match */ /** @todo check argument type for match */
// mismatch parameter: passing parameter by address to function, argument is reference // mismatch parameter: passing parameter by address to function, argument is reference