diff options
author | David Majnemer <david.majnemer@gmail.com> | 2014-08-23 01:48:50 +0000 |
---|---|---|
committer | David Majnemer <david.majnemer@gmail.com> | 2014-08-23 01:48:50 +0000 |
commit | 58e4ea904bf625ea621ccebd513f58496886f918 (patch) | |
tree | fa7b410f5f9389dc4cbf7c6352102c46dc78d3e5 /clang/lib/Sema/SemaInit.cpp | |
parent | 88ebade8d9f8c9b3f818ee43acd8960ec6475952 (diff) | |
download | bcm5719-llvm-58e4ea904bf625ea621ccebd513f58496886f918.tar.gz bcm5719-llvm-58e4ea904bf625ea621ccebd513f58496886f918.zip |
CodeGen: Skip unnamed bitfields when handling designated initializers
We would accidently initialize unnamed bitfields instead of the
following field.
llvm-svn: 216313
Diffstat (limited to 'clang/lib/Sema/SemaInit.cpp')
-rw-r--r-- | clang/lib/Sema/SemaInit.cpp | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/clang/lib/Sema/SemaInit.cpp b/clang/lib/Sema/SemaInit.cpp index 79fe8db2379..326bfc90875 100644 --- a/clang/lib/Sema/SemaInit.cpp +++ b/clang/lib/Sema/SemaInit.cpp @@ -1932,7 +1932,15 @@ InitListChecker::CheckDesignatedInitializer(const InitializedEntity &Entity, } } - unsigned FieldIndex = KnownField->getFieldIndex(); + unsigned FieldIndex = 0; + for (auto *FI : RT->getDecl()->fields()) { + if (FI->isUnnamedBitfield()) + continue; + if (KnownField == FI) + break; + ++FieldIndex; + } + RecordDecl::field_iterator Field = RecordDecl::field_iterator(DeclContext::decl_iterator(KnownField)); |