]> granicus.if.org Git - clang/commitdiff
Start populating the VtableMembers structure.
authorAnders Carlsson <andersca@mac.com>
Fri, 4 Dec 2009 02:08:24 +0000 (02:08 +0000)
committerAnders Carlsson <andersca@mac.com>
Fri, 4 Dec 2009 02:08:24 +0000 (02:08 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@90517 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/CGVtable.cpp

index 46a0bab035b2eeca7ec12b68017130852015c2ca..b8860841ab3e4c63469cf84e47050f9ddd7874c8 100644 (file)
@@ -421,7 +421,10 @@ public:
 
     const CXXMethodDecl *MD = cast<CXXMethodDecl>(GD.getDecl());
     
-    // else allocate a new slot.
+    // We didn't find an entry in the vtable that we could use, add a new
+    // entry.
+    Methods.AddMethod(GD);
+
     Index[GD] = submethods.size();
     submethods.push_back(m);
     D1(printf("  vfn for %s at %d\n", MD->getNameAsString().c_str(),
@@ -553,9 +556,13 @@ public:
     methods.push_back(rtti);
     Index_t AddressPoint = methods.size();
 
+    assert(submethods.size() == Methods.size() && "Method size mismatch!");
+
     InstallThunks();
     D1(printf("============= combining methods\n"));
     methods.insert(methods.end(), submethods.begin(), submethods.end());
+    
+    Methods.clear();
     submethods.clear();
 
     // and then the non-virtual bases.
@@ -864,6 +871,8 @@ bool VtableBuilder::OverrideMethod(GlobalDecl GD, llvm::Constant *m,
         Adjustment.GD = GD;
       }
 
+      Methods.OverrideMethod(OGD, GD);
+
       Index[GD] = i;
       submethods[i] = m;
       if (isPure)