diff options
| author | Fariborz Jahanian <fjahanian@apple.com> | 2011-04-28 22:49:46 +0000 |
|---|---|---|
| committer | Fariborz Jahanian <fjahanian@apple.com> | 2011-04-28 22:49:46 +0000 |
| commit | 8409bce4aca162fad81e43f84cece1b9b13cde77 (patch) | |
| tree | 941fdab26edf4c880baf6e51154bfa84af91fa26 /clang/lib/AST | |
| parent | 80d1d3aaecb5eb086cd568114716d20bcf40c793 (diff) | |
| download | bcm5719-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.cpp | 15 |
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; } |

