aboutsummaryrefslogtreecommitdiff
path: root/lib/CodeGen/CGCXX.cpp
diff options
context:
space:
mode:
authorMike Stump <mrs@apple.com>2009-09-05 08:37:03 +0000
committerMike Stump <mrs@apple.com>2009-09-05 08:37:03 +0000
commit9bbe962611ebdcfdd1e5e312113ad4efd13472b2 (patch)
tree31c93e42c51717e1fcba14df2b3c3d190be418b6 /lib/CodeGen/CGCXX.cpp
parentbf595a3b1f1737eb60203856ea34b759c4c09c46 (diff)
Cleanups.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@81072 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/CGCXX.cpp')
-rw-r--r--lib/CodeGen/CGCXX.cpp34
1 files changed, 29 insertions, 5 deletions
diff --git a/lib/CodeGen/CGCXX.cpp b/lib/CodeGen/CGCXX.cpp
index 7d2866aeaa..e9312ec57e 100644
--- a/lib/CodeGen/CGCXX.cpp
+++ b/lib/CodeGen/CGCXX.cpp
@@ -1077,6 +1077,32 @@ public:
return AddressPoint;
}
+ void Primaries(const CXXRecordDecl *RD, bool forPrimary,
+ bool MorallyVirtual, int64_t Offset, bool ForVirtualBase) {
+ if (!RD->isDynamicClass())
+ return;
+
+ const ASTRecordLayout &Layout = CGM.getContext().getASTRecordLayout(RD);
+ const CXXRecordDecl *PrimaryBase = Layout.getPrimaryBase();
+ const bool PrimaryBaseWasVirtual = Layout.getPrimaryBaseWasVirtual();
+
+ std::vector<llvm::Constant *> offsets;
+
+ bool Top = true;
+
+ // vtables are composed from the chain of primaries.
+ if (PrimaryBase) {
+ if (PrimaryBaseWasVirtual)
+ IndirectPrimary.insert(PrimaryBase);
+ Top = false;
+ Primaries(PrimaryBase, true, PrimaryBaseWasVirtual|MorallyVirtual,
+ Offset, PrimaryBaseWasVirtual);
+ }
+
+ // And add the virtuals for the class to the primary vtable.
+ AddMethods(RD, MorallyVirtual, Offset);
+ }
+
int64_t GenerateVtableForBase(const CXXRecordDecl *RD, bool forPrimary,
bool Bottom, bool MorallyVirtual,
int64_t Offset, bool ForVirtualBase) {
@@ -1089,8 +1115,7 @@ public:
std::vector<llvm::Constant *> offsets;
// FIXME: Audit, is this right?
- if (Bottom && (PrimaryBase == 0 || forPrimary || !PrimaryBaseWasVirtual
- || Bottom)) {
+ if (Bottom) {
extra = 0;
GenerateVBaseOffsets(offsets, RD, Offset);
if (ForVirtualBase)
@@ -1104,9 +1129,8 @@ public:
if (PrimaryBaseWasVirtual)
IndirectPrimary.insert(PrimaryBase);
Top = false;
- GenerateVtableForBase(PrimaryBase, true, false,
- PrimaryBaseWasVirtual|MorallyVirtual, Offset,
- PrimaryBaseWasVirtual);
+ Primaries(PrimaryBase, true, PrimaryBaseWasVirtual|MorallyVirtual,
+ Offset, PrimaryBaseWasVirtual);
}
// And add the virtuals for the class to the primary vtable.