summaryrefslogtreecommitdiffstats
path: root/clang/lib/AST
diff options
context:
space:
mode:
authorFariborz Jahanian <fjahanian@apple.com>2011-04-28 22:49:46 +0000
committerFariborz Jahanian <fjahanian@apple.com>2011-04-28 22:49:46 +0000
commit8409bce4aca162fad81e43f84cece1b9b13cde77 (patch)
tree941fdab26edf4c880baf6e51154bfa84af91fa26 /clang/lib/AST
parent80d1d3aaecb5eb086cd568114716d20bcf40c793 (diff)
downloadbcm5719-llvm-8409bce4aca162fad81e43f84cece1b9b13cde77.tar.gz
bcm5719-llvm-8409bce4aca162fad81e43f84cece1b9b13cde77.zip
ms_struct patch for initialization and field access irgen.
// rdar://8823265 - wip. llvm-svn: 130451
Diffstat (limited to 'clang/lib/AST')
-rw-r--r--clang/lib/AST/Decl.cpp15
1 files changed, 13 insertions, 2 deletions
diff --git a/clang/lib/AST/Decl.cpp b/clang/lib/AST/Decl.cpp
index d37099f8644..89c7d47cb71 100644
--- a/clang/lib/AST/Decl.cpp
+++ b/clang/lib/AST/Decl.cpp
@@ -2047,13 +2047,24 @@ unsigned FieldDecl::getFieldIndex() const {
if (CachedFieldIndex) return CachedFieldIndex - 1;
unsigned index = 0;
- RecordDecl::field_iterator
- i = getParent()->field_begin(), e = getParent()->field_end();
+ const RecordDecl *RD = getParent();
+ const FieldDecl *LastFD = 0;
+ bool IsMsStruct = RD->hasAttr<MsStructAttr>();
+
+ RecordDecl::field_iterator i = RD->field_begin(), e = RD->field_end();
while (true) {
assert(i != e && "failed to find field in parent!");
if (*i == this)
break;
+ if (IsMsStruct) {
+ // Zero-length bitfields following non-bitfield members are ignored.
+ if (getASTContext().ZeroBitfieldFollowsNonBitfield((*i), LastFD)) {
+ ++i;
+ continue;
+ }
+ LastFD = (*i);
+ }
++i;
++index;
}
OpenPOWER on IntegriCloud