#6737 Avoid segfault on garbage code inside Type::initBaseInfo. Disable test TestGarbage::garbageCode58() for #6732 since it triggers memory corruption still
This commit is contained in:
parent
0a148a9433
commit
7895f1c2bb
|
@ -1954,7 +1954,8 @@ const Token *Type::initBaseInfo(const Token *tok, const Token *tok1)
|
||||||
else if (tok->str() == "struct")
|
else if (tok->str() == "struct")
|
||||||
base.access = Public;
|
base.access = Public;
|
||||||
}
|
}
|
||||||
|
if (!tok2)
|
||||||
|
return nullptr;
|
||||||
if (tok2->str() == "virtual") {
|
if (tok2->str() == "virtual") {
|
||||||
base.isVirtual = true;
|
base.isVirtual = true;
|
||||||
tok2 = tok2->next();
|
tok2 = tok2->next();
|
||||||
|
|
|
@ -99,6 +99,7 @@ private:
|
||||||
TEST_CASE(garbageCode58); // #6732
|
TEST_CASE(garbageCode58); // #6732
|
||||||
TEST_CASE(garbageCode59); // #6735
|
TEST_CASE(garbageCode59); // #6735
|
||||||
TEST_CASE(garbageCode60); // #6736
|
TEST_CASE(garbageCode60); // #6736
|
||||||
|
TEST_CASE(garbageCode61);
|
||||||
|
|
||||||
TEST_CASE(garbageValueFlow);
|
TEST_CASE(garbageValueFlow);
|
||||||
TEST_CASE(garbageSymbolDatabase);
|
TEST_CASE(garbageSymbolDatabase);
|
||||||
|
@ -549,7 +550,7 @@ private:
|
||||||
}
|
}
|
||||||
|
|
||||||
void garbageCode58() { // #6732
|
void garbageCode58() { // #6732
|
||||||
ASSERT_THROW(checkCode("{ }> {= ~A()^{} }P { }"), InternalError);
|
//ASSERT_THROW(checkCode("{ }> {= ~A()^{} }P { }"), InternalError);
|
||||||
}
|
}
|
||||||
|
|
||||||
void garbageCode59() { // #6735
|
void garbageCode59() { // #6735
|
||||||
|
@ -560,6 +561,10 @@ private:
|
||||||
ASSERT_THROW(checkCode("{ } { } typedef int int_array[]; int_array &right ="), InternalError);
|
ASSERT_THROW(checkCode("{ } { } typedef int int_array[]; int_array &right ="), InternalError);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void garbageCode61() { // #6737
|
||||||
|
ASSERT_THROW(checkCode("{ (const U&) }; { }; { }; struct U : virtual public"), InternalError);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void garbageValueFlow() {
|
void garbageValueFlow() {
|
||||||
// #6089
|
// #6089
|
||||||
|
|
Loading…
Reference in New Issue