Fixed #7810 (SymbolDatabase: method with redundant scope info)
This commit is contained in:
parent
5d7a4d51ad
commit
79fc332511
|
@ -355,7 +355,7 @@ SymbolDatabase::SymbolDatabase(const Tokenizer *tokenizer, const Settings *setti
|
||||||
|
|
||||||
// class function?
|
// class function?
|
||||||
else if (isFunction(tok, scope, &funcStart, &argStart, &declEnd)) {
|
else if (isFunction(tok, scope, &funcStart, &argStart, &declEnd)) {
|
||||||
if (tok->previous()->str() != "::") {
|
if (tok->previous()->str() != "::" || tok->strAt(-2) == scope->className) {
|
||||||
Function function;
|
Function function;
|
||||||
|
|
||||||
// save the function definition argument start '('
|
// save the function definition argument start '('
|
||||||
|
|
|
@ -152,6 +152,7 @@ private:
|
||||||
TEST_CASE(hasInlineClassFunctionReturningFunctionPointer);
|
TEST_CASE(hasInlineClassFunctionReturningFunctionPointer);
|
||||||
TEST_CASE(hasMissingInlineClassFunctionReturningFunctionPointer);
|
TEST_CASE(hasMissingInlineClassFunctionReturningFunctionPointer);
|
||||||
TEST_CASE(hasClassFunctionReturningFunctionPointer);
|
TEST_CASE(hasClassFunctionReturningFunctionPointer);
|
||||||
|
TEST_CASE(methodWithRedundantScope);
|
||||||
TEST_CASE(complexFunctionArrayPtr);
|
TEST_CASE(complexFunctionArrayPtr);
|
||||||
TEST_CASE(pointerToMemberFunction);
|
TEST_CASE(pointerToMemberFunction);
|
||||||
TEST_CASE(hasSubClassConstructor);
|
TEST_CASE(hasSubClassConstructor);
|
||||||
|
@ -1120,6 +1121,27 @@ private:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void methodWithRedundantScope() {
|
||||||
|
GET_SYMBOL_DB("class Fred { void Fred::func() {} };\n")
|
||||||
|
|
||||||
|
// 3 scopes: Global, Class, and Function
|
||||||
|
ASSERT(db && db->scopeList.size() == 3);
|
||||||
|
|
||||||
|
if (db) {
|
||||||
|
const Token * const functionToken = Token::findsimplematch(tokenizer.tokens(), "func");
|
||||||
|
|
||||||
|
const Scope *scope = findFunctionScopeByToken(db, functionToken);
|
||||||
|
|
||||||
|
ASSERT(scope && scope->className == "func");
|
||||||
|
|
||||||
|
const Function *function = findFunctionByName("func", &db->scopeList.back());
|
||||||
|
|
||||||
|
ASSERT(function && function->token->str() == "func");
|
||||||
|
ASSERT(function && function->token == functionToken);
|
||||||
|
ASSERT(function && function->hasBody() && function->isInline());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void complexFunctionArrayPtr() {
|
void complexFunctionArrayPtr() {
|
||||||
GET_SYMBOL_DB("int(*p1)[10]; \n" // pointer to array 10 of int
|
GET_SYMBOL_DB("int(*p1)[10]; \n" // pointer to array 10 of int
|
||||||
"void(*p2)(char); \n" // pointer to function (char) returning void
|
"void(*p2)(char); \n" // pointer to function (char) returning void
|
||||||
|
|
Loading…
Reference in New Issue