summaryrefslogtreecommitdiffstats
path: root/clang/lib/AST/RecordLayoutBuilder.cpp
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2010-05-26 05:10:47 +0000
committerAnders Carlsson <andersca@mac.com>2010-05-26 05:10:47 +0000
commitd295486012ab96240fbfcc5da41a52eaf81e6a25 (patch)
treeac4c21a29f8e6564d71995ede1fd75d505134988 /clang/lib/AST/RecordLayoutBuilder.cpp
parent6ed3a9a4942d81e2ce6e70a36972f3aa35a14e00 (diff)
downloadbcm5719-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.cpp39
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) {
OpenPOWER on IntegriCloud