From: Mike Stump Date: Wed, 12 Aug 2009 23:14:12 +0000 (+0000) Subject: Refactor. WIP. Eventually, this will all go into a vtable builder class. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=4c3aedd3f1fff57d1906b0cdfa7a9ec81a361b2d;p=clang Refactor. WIP. Eventually, this will all go into a vtable builder class. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@78857 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/CGCXX.cpp b/lib/CodeGen/CGCXX.cpp index 31b406aed2..1c95fc313e 100644 --- a/lib/CodeGen/CGCXX.cpp +++ b/lib/CodeGen/CGCXX.cpp @@ -621,6 +621,21 @@ llvm::Constant *CodeGenFunction::GenerateRtti(const CXXRecordDecl *RD) { return Rtti; } +void CodeGenFunction::GenerateVcalls(std::vector &methods, + const CXXRecordDecl *RD, + llvm::Type *Ptr8Ty) { + typedef CXXRecordDecl::method_iterator meth_iter; + llvm::Constant *m; + for (meth_iter mi = RD->method_begin(), + me = RD->method_end(); mi != me; ++mi) { + if (mi->isVirtual()) { + // FIXME: vcall: offset for virtual base for this function + m = llvm::Constant::getNullValue(Ptr8Ty); + methods.push_back(m); + } + } +} + void CodeGenFunction::GenerateMethods(std::vector &methods, const CXXRecordDecl *RD, llvm::Type *Ptr8Ty) { @@ -673,14 +688,8 @@ void CodeGenFunction::GenerateVtableForBase(const CXXRecordDecl *RD, // then comes the the vcall offsets for all our functions... if (isPrimary && ForVirtualBase) - for (meth_iter mi = Class->method_begin(), - me = Class->method_end(); mi != me; ++mi) { - if (mi->isVirtual()) { - // FIXME: vcall: offset for virtual base for this function - m = llvm::Constant::getNullValue(Ptr8Ty); - methods.push_back(m); - } - } + GenerateVcalls(methods, Class, Ptr8Ty); + bool TopPrimary = true; // Primary tables are composed from the chain of primaries. if (isPrimary) { @@ -696,14 +705,7 @@ void CodeGenFunction::GenerateVtableForBase(const CXXRecordDecl *RD, } // then come the vcall offsets for all our virtual bases. if (!isPrimary && RD && ForVirtualBase) - for (meth_iter mi = RD->method_begin(), me = RD->method_end(); mi != me; - ++mi) { - if (mi->isVirtual()) { - // FIXME: vcall: offset for virtual base for this function - m = llvm::Constant::getNullValue(Ptr8Ty); - methods.push_back(m); - } - } + GenerateVcalls(methods, RD, Ptr8Ty); if (TopPrimary) { if (RD) { diff --git a/lib/CodeGen/CodeGenFunction.h b/lib/CodeGen/CodeGenFunction.h index 75dd3f55f9..4375fbccc7 100644 --- a/lib/CodeGen/CodeGenFunction.h +++ b/lib/CodeGen/CodeGenFunction.h @@ -359,6 +359,8 @@ public: void FinishFunction(SourceLocation EndLoc=SourceLocation()); llvm::Constant *GenerateRtti(const CXXRecordDecl *RD); + void GenerateVcalls(std::vector &methods, + const CXXRecordDecl *RD, llvm::Type *Ptr8Ty); void GenerateMethods(std::vector &methods, const CXXRecordDecl *RD, llvm::Type *Ptr8Ty); void GenerateVtableForBase(const CXXRecordDecl *RD,