diff options
author | Eli Friedman <eli.friedman@gmail.com> | 2008-08-09 23:45:45 +0000 |
---|---|---|
committer | Eli Friedman <eli.friedman@gmail.com> | 2008-08-09 23:45:45 +0000 |
commit | a3b2f6f2af5afad707a91b33b260b769fb57bf7f (patch) | |
tree | 0f12cdb19967797cc4231059e6821709e5e05606 /clang/lib | |
parent | 121ba0c4d34b59512db1309fc2e511e0b36a5fe0 (diff) | |
download | bcm5719-llvm-a3b2f6f2af5afad707a91b33b260b769fb57bf7f.tar.gz bcm5719-llvm-a3b2f6f2af5afad707a91b33b260b769fb57bf7f.zip |
Make sure to count the struct elements correctly; here, we want the
member count. The count returned by numStructUnionElements is the
number of initializers that will be consumed, not the number of members
to iterate through. Fixes PR2534.
llvm-svn: 54601
Diffstat (limited to 'clang/lib')
-rw-r--r-- | clang/lib/Sema/SemaInit.cpp | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/clang/lib/Sema/SemaInit.cpp b/clang/lib/Sema/SemaInit.cpp index 1889bafacb0..bc38de3633a 100644 --- a/clang/lib/Sema/SemaInit.cpp +++ b/clang/lib/Sema/SemaInit.cpp @@ -286,7 +286,8 @@ void InitListChecker::CheckStructUnionTypes(InitListExpr *IList, // If structDecl is a forward declaration, this loop won't do anything; // That's okay, because an error should get printed out elsewhere. It // might be worthwhile to skip over the rest of the initializer, though. - int numMembers = numStructUnionElements(DeclType); + int numMembers = DeclType->getAsRecordType()->getDecl()->getNumMembers() - + structDecl->hasFlexibleArrayMember(); for (int i = 0; i < numMembers; i++) { // Don't attempt to go past the end of the init list if (Index >= IList->getNumInits()) |