// Otherwise if is the first nearly empty virtual base, if one exists,
// otherwise there is no primary base class.
- setPrimaryBase(FirstPrimary, true);
- return;
+ if (!PrimaryBase)
+ setPrimaryBase(FirstPrimary, true);
}
void ASTRecordLayoutBuilder::LayoutVirtualBase(const CXXRecordDecl *RD) {
--- /dev/null
+// RUN: clang-cc -fsyntax-only -verify %s
+class A { virtual void f(); };
+class B : virtual A { };
+
+class C : B { };
+
+// Since A is already a primary base class, C should be the primary base class of F.
+class F : virtual A, virtual C { };
+
+int sa[sizeof(F) == sizeof(A) ? 1 : -1];
+