diff options
| author | Anders Carlsson <andersca@mac.com> | 2010-05-26 05:10:47 +0000 |
|---|---|---|
| committer | Anders Carlsson <andersca@mac.com> | 2010-05-26 05:10:47 +0000 |
| commit | d295486012ab96240fbfcc5da41a52eaf81e6a25 (patch) | |
| tree | ac4c21a29f8e6564d71995ede1fd75d505134988 /clang/lib/AST/RecordLayoutBuilder.cpp | |
| parent | 6ed3a9a4942d81e2ce6e70a36972f3aa35a14e00 (diff) | |
| download | bcm5719-llvm-d295486012ab96240fbfcc5da41a52eaf81e6a25.tar.gz bcm5719-llvm-d295486012ab96240fbfcc5da41a52eaf81e6a25.zip | |
Fold the other Layout overload into its sole call site.
llvm-svn: 104673
Diffstat (limited to 'clang/lib/AST/RecordLayoutBuilder.cpp')
| -rw-r--r-- | clang/lib/AST/RecordLayoutBuilder.cpp | 39 |
1 files changed, 37 insertions, 2 deletions
diff --git a/clang/lib/AST/RecordLayoutBuilder.cpp b/clang/lib/AST/RecordLayoutBuilder.cpp index a255ff41ae3..b65e98180e0 100644 --- a/clang/lib/AST/RecordLayoutBuilder.cpp +++ b/clang/lib/AST/RecordLayoutBuilder.cpp @@ -967,8 +967,43 @@ const ASTRecordLayout &ASTContext::getASTRecordLayout(const RecordDecl *D) { const ASTRecordLayout *Entry = ASTRecordLayouts[D]; if (Entry) return *Entry; - const ASTRecordLayout *NewEntry = - ASTRecordLayoutBuilder::ComputeLayout(*this, D); + const ASTRecordLayout *NewEntry; + + if (const CXXRecordDecl *RD = dyn_cast<CXXRecordDecl>(D)) { + ASTRecordLayoutBuilder Builder(*this); + Builder.Layout(RD); + + // FIXME: This is not always correct. See the part about bitfields at + // http://www.codesourcery.com/public/cxx-abi/abi.html#POD for more info. + // FIXME: IsPODForThePurposeOfLayout should be stored in the record layout. + bool IsPODForThePurposeOfLayout = cast<CXXRecordDecl>(D)->isPOD(); + + // FIXME: This should be done in FinalizeLayout. + uint64_t DataSize = + IsPODForThePurposeOfLayout ? Builder.Size : Builder.DataSize; + uint64_t NonVirtualSize = + IsPODForThePurposeOfLayout ? DataSize : Builder.NonVirtualSize; + + NewEntry = + new (*this) ASTRecordLayout(*this, Builder.Size, Builder.Alignment, + DataSize, Builder.FieldOffsets.data(), + Builder.FieldOffsets.size(), + NonVirtualSize, + Builder.NonVirtualAlignment, + Builder.SizeOfLargestEmptySubobject, + Builder.PrimaryBase, + Builder.Bases, Builder.VBases); + } else { + ASTRecordLayoutBuilder Builder(*this); + Builder.Layout(D); + + NewEntry = + new (*this) ASTRecordLayout(*this, Builder.Size, Builder.Alignment, + Builder.Size, + Builder.FieldOffsets.data(), + Builder.FieldOffsets.size()); + } + ASTRecordLayouts[D] = NewEntry; if (getLangOptions().DumpRecordLayouts) { |

