#7018 segmentation fault (invalid code) in Tokenizer::simplifyEnum
This commit is contained in:
parent
2fbb25e9bc
commit
fde59242bb
|
@ -7434,7 +7434,7 @@ void Tokenizer::simplifyEnum()
|
||||||
enumName = tok1;
|
enumName = tok1;
|
||||||
lastValue = 0;
|
lastValue = 0;
|
||||||
tok1 = tok1->tokAt(2);
|
tok1 = tok1->tokAt(2);
|
||||||
if (Token::Match(tok1, ",|{|}"))
|
if (!tok1 || Token::Match(tok1, ",|{|}"))
|
||||||
syntaxError(tok1);
|
syntaxError(tok1);
|
||||||
|
|
||||||
enumValueStart = tok1;
|
enumValueStart = tok1;
|
||||||
|
@ -7442,6 +7442,8 @@ void Tokenizer::simplifyEnum()
|
||||||
while (enumValueEnd->next() && (!Token::Match(enumValueEnd->next(), "[},]"))) {
|
while (enumValueEnd->next() && (!Token::Match(enumValueEnd->next(), "[},]"))) {
|
||||||
if (Token::Match(enumValueEnd, "(|[")) {
|
if (Token::Match(enumValueEnd, "(|[")) {
|
||||||
enumValueEnd = enumValueEnd->link();
|
enumValueEnd = enumValueEnd->link();
|
||||||
|
if (!enumValueEnd) // #7018 invalid code
|
||||||
|
syntaxError(nullptr);
|
||||||
continue;
|
continue;
|
||||||
} else if (isCPP() && Token::Match(enumValueEnd, "%type% <") && TemplateSimplifier::templateParameters(enumValueEnd->next()) >= 1U) {
|
} else if (isCPP() && Token::Match(enumValueEnd, "%type% <") && TemplateSimplifier::templateParameters(enumValueEnd->next()) >= 1U) {
|
||||||
Token *endtoken = enumValueEnd->next()->findClosingBracket();
|
Token *endtoken = enumValueEnd->next()->findClosingBracket();
|
||||||
|
@ -7452,8 +7454,9 @@ void Tokenizer::simplifyEnum()
|
||||||
} else
|
} else
|
||||||
syntaxError(enumValueEnd);
|
syntaxError(enumValueEnd);
|
||||||
}
|
}
|
||||||
|
|
||||||
enumValueEnd = enumValueEnd->next();
|
enumValueEnd = enumValueEnd->next();
|
||||||
|
if (!enumValueEnd) // #7018 invalid code
|
||||||
|
syntaxError(nullptr);
|
||||||
}
|
}
|
||||||
// remember this expression in case it needs to be incremented
|
// remember this expression in case it needs to be incremented
|
||||||
lastEnumValueStart = enumValueStart;
|
lastEnumValueStart = enumValueStart;
|
||||||
|
|
|
@ -167,6 +167,7 @@ private:
|
||||||
TEST_CASE(garbageCode125); // 6782, 6834
|
TEST_CASE(garbageCode125); // 6782, 6834
|
||||||
TEST_CASE(garbageCode126); // #6997
|
TEST_CASE(garbageCode126); // #6997
|
||||||
TEST_CASE(garbageCode127); // #6667
|
TEST_CASE(garbageCode127); // #6667
|
||||||
|
TEST_CASE(garbageCode128); // #7018
|
||||||
|
|
||||||
TEST_CASE(garbageValueFlow);
|
TEST_CASE(garbageValueFlow);
|
||||||
TEST_CASE(garbageSymbolDatabase);
|
TEST_CASE(garbageSymbolDatabase);
|
||||||
|
@ -965,6 +966,11 @@ private:
|
||||||
" foo(A(12)).Var\n");
|
" foo(A(12)).Var\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void garbageCode128() {
|
||||||
|
ASSERT_THROW(checkCode("enum { FOO = ( , ) } {{ }} enum {{ FOO << = } ( ) } {{ }} ;"),
|
||||||
|
InternalError);
|
||||||
|
}
|
||||||
|
|
||||||
void garbageValueFlow() {
|
void garbageValueFlow() {
|
||||||
// #6089
|
// #6089
|
||||||
const char* code = "{} int foo(struct, x1, struct x2, x3, int, x5, x6, x7)\n"
|
const char* code = "{} int foo(struct, x1, struct x2, x3, int, x5, x6, x7)\n"
|
||||||
|
|
Loading…
Reference in New Issue