Fixed #7976 (Internal error. Token::astOperand1() cyclic dependency. (ticket nr 2, new regression))

This commit is contained in:
Daniel Marjamäki 2017-04-05 11:00:02 +02:00
parent 1f83c014d5
commit e6ed08c4d8
2 changed files with 10 additions and 5 deletions

View File

@ -1014,11 +1014,15 @@ static void createAstAtTokenInner(Token * const tok1, const Token *endToken, boo
tok->astParent()->astParent()->astOperand1() && tok->astParent()->astParent()->astOperand1() &&
tok == tok->astParent()->astParent()->astOperand1()->astOperand1()) tok == tok->astParent()->astParent()->astOperand1()->astOperand1())
; ;
// function argument is initializer list else {
else if (tok->astParent() && (tok->astParent()->str() == "," || Token::Match(tok->astParent()->previous(), "%name% ("))) // function argument is initializer list?
; const Token *parent = tok->astParent();
else while (Token::simpleMatch(parent, ","))
continue; parent = parent->astParent();
if (!parent || !Token::Match(parent->previous(), "%name% ("))
// not function argument..
continue;
}
if (Token::simpleMatch(tok->previous(), "( { .")) if (Token::simpleMatch(tok->previous(), "( { ."))
break; break;

View File

@ -8054,6 +8054,7 @@ private:
// struct initialization // struct initialization
ASSERT_EQUALS("name_bytes[bits~unusedBits>>unusedBits<<{=", testAst("const uint8_t name_bytes[] = { (~bits >> unusedBits) << unusedBits };")); ASSERT_EQUALS("name_bytes[bits~unusedBits>>unusedBits<<{=", testAst("const uint8_t name_bytes[] = { (~bits >> unusedBits) << unusedBits };"));
ASSERT_EQUALS("abuf0{={=", testAst("a = { .buf = { 0 } };")); ASSERT_EQUALS("abuf0{={=", testAst("a = { .buf = { 0 } };"));
ASSERT_EQUALS("ab2[a0=b0=,{a0=b0=,{,{=", testAst("struct AB ab[2] = { { .a=0, .b=0 }, { .a=0, .b=0 } };"));
ASSERT_EQUALS("tset{=", testAst("struct cgroup_taskset tset = {};")); ASSERT_EQUALS("tset{=", testAst("struct cgroup_taskset tset = {};"));
ASSERT_EQUALS("s1a&,{2b&,{,{=", testAst("s = { {1, &a}, {2, &b} };")); ASSERT_EQUALS("s1a&,{2b&,{,{=", testAst("s = { {1, &a}, {2, &b} };"));