Fix some new SymbolDatabase bailout; unhandled code syntax errors. (#1152)
This commit is contained in:
parent
05acf9b352
commit
7e15e39f39
|
@ -83,8 +83,10 @@ void SymbolDatabase::createSymbolDatabaseFindAllScopes()
|
||||||
"SymbolDatabase",
|
"SymbolDatabase",
|
||||||
tok->progressValue());
|
tok->progressValue());
|
||||||
// Locate next class
|
// Locate next class
|
||||||
if ((_tokenizer->isCPP() && ((Token::Match(tok, "class|struct|union|namespace ::| %name% {|:|::|<") && tok->strAt(-1) != "friend") ||
|
if ((_tokenizer->isCPP() && ((Token::Match(tok, "class|struct|union|namespace ::| %name% {|:|::|<") &&
|
||||||
(Token::Match(tok, "enum class| %name% {") || Token::Match(tok, "enum class| %name% : %name% {"))))
|
!Token::Match(tok->previous(), "new|friend|)|(")) ||
|
||||||
|
(Token::Match(tok, "enum class| %name% {") ||
|
||||||
|
Token::Match(tok, "enum class| %name% : %name% {"))))
|
||||||
|| (_tokenizer->isC() && Token::Match(tok, "struct|union|enum %name% {"))) {
|
|| (_tokenizer->isC() && Token::Match(tok, "struct|union|enum %name% {"))) {
|
||||||
const Token *tok2 = tok->tokAt(2);
|
const Token *tok2 = tok->tokAt(2);
|
||||||
|
|
||||||
|
|
|
@ -272,6 +272,7 @@ private:
|
||||||
TEST_CASE(symboldatabase58); // #6985 (using namespace type lookup)
|
TEST_CASE(symboldatabase58); // #6985 (using namespace type lookup)
|
||||||
TEST_CASE(symboldatabase59);
|
TEST_CASE(symboldatabase59);
|
||||||
TEST_CASE(symboldatabase60);
|
TEST_CASE(symboldatabase60);
|
||||||
|
TEST_CASE(symboldatabase61);
|
||||||
|
|
||||||
TEST_CASE(enum1);
|
TEST_CASE(enum1);
|
||||||
TEST_CASE(enum2);
|
TEST_CASE(enum2);
|
||||||
|
@ -2896,6 +2897,21 @@ private:
|
||||||
ASSERT(db && db->scopeList.size() == 2);
|
ASSERT(db && db->scopeList.size() == 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void symboldatabase61() {
|
||||||
|
GET_SYMBOL_DB("struct Fred {\n"
|
||||||
|
" struct Info { };\n"
|
||||||
|
"};\n"
|
||||||
|
"void foo() {\n"
|
||||||
|
" struct Fred::Info* info;\n"
|
||||||
|
" info = new (nothrow) struct Fred::Info();\n"
|
||||||
|
" info = new struct Fred::Info();\n"
|
||||||
|
" memset(info, 0, sizeof(struct Fred::Info));\n"
|
||||||
|
"}");
|
||||||
|
|
||||||
|
ASSERT(db != nullptr);
|
||||||
|
ASSERT(db && db->scopeList.size() == 4);
|
||||||
|
}
|
||||||
|
|
||||||
void enum1() {
|
void enum1() {
|
||||||
GET_SYMBOL_DB("enum BOOL { FALSE, TRUE }; enum BOOL b;");
|
GET_SYMBOL_DB("enum BOOL { FALSE, TRUE }; enum BOOL b;");
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue