summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema/SemaInit.cpp
diff options
context:
space:
mode:
authorDavid Majnemer <david.majnemer@gmail.com>2014-08-23 01:48:50 +0000
committerDavid Majnemer <david.majnemer@gmail.com>2014-08-23 01:48:50 +0000
commit58e4ea904bf625ea621ccebd513f58496886f918 (patch)
treefa7b410f5f9389dc4cbf7c6352102c46dc78d3e5 /clang/lib/Sema/SemaInit.cpp
parent88ebade8d9f8c9b3f818ee43acd8960ec6475952 (diff)
downloadbcm5719-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.cpp10
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));
OpenPOWER on IntegriCloud