diff options
-rw-r--r-- | lib/AST/RecordLayoutBuilder.cpp | 9 | ||||
-rw-r--r-- | test/SemaCXX/empty-class-layout.cpp | 11 |
2 files changed, 5 insertions, 15 deletions
diff --git a/lib/AST/RecordLayoutBuilder.cpp b/lib/AST/RecordLayoutBuilder.cpp index 69e31a3072..43dee104ba 100644 --- a/lib/AST/RecordLayoutBuilder.cpp +++ b/lib/AST/RecordLayoutBuilder.cpp @@ -1867,13 +1867,14 @@ void RecordLayoutBuilder::LayoutField(const FieldDecl *D) { Context.toBits(UnpackedFieldAlign), FieldPacked, D); // Reserve space for this field. + uint64_t FieldSizeInBits = Context.toBits(FieldSize); if (IsUnion) - setDataSize(std::max(getDataSize(), FieldSize)); + setSize(std::max(getSizeInBits(), FieldSizeInBits)); else - setDataSize(FieldOffset + FieldSize); + setSize(FieldOffset + FieldSize); - // Update the size. - setSize(std::max(getSize(), getDataSize())); + // Update the data size. + setDataSize(getSizeInBits()); // Remember max struct/class alignment. UpdateAlignment(FieldAlign, UnpackedFieldAlign); diff --git a/test/SemaCXX/empty-class-layout.cpp b/test/SemaCXX/empty-class-layout.cpp index c68f2bb6fb..0b46bf045a 100644 --- a/test/SemaCXX/empty-class-layout.cpp +++ b/test/SemaCXX/empty-class-layout.cpp @@ -144,14 +144,3 @@ struct B : Empty, A { }; SA(0, sizeof(B) == 16); } - -namespace Test7 { - // Make sure we reserve enough space for both bases; PR11745. - struct Empty { }; - struct Base1 : Empty { }; - struct Base2 : Empty { }; - struct Test : Base1, Base2 { - char c; - }; - SA(0, sizeof(Test) == 2); -} |