Move handling of pure virtual methods to AppendMethods (and rename it to AppendMethodsToVtable).

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@90529 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Anders Carlsson 2009-12-04 02:56:03 +00:00
Родитель ea357223e5
Коммит bf54027d27
1 изменённых файлов: 6 добавлений и 14 удалений

Просмотреть файл

@ -289,17 +289,8 @@ public:
Index_t Offset, int64_t CurrentVBaseOffset);
/// AppendMethods - Append the current methods to the vtable.
void AppendMethods();
void AppendMethodsToVtable();
void InstallThunks() {
for (PureVirtualMethodsSetTy::iterator i = PureVirtualMethods.begin(),
e = PureVirtualMethods.end(); i != e; ++i) {
GlobalDecl GD = *i;
submethods[Index[GD]] = getPureVirtualFn();
}
PureVirtualMethods.clear();
}
llvm::Constant *WrapAddrOf(GlobalDecl GD) {
const CXXMethodDecl *MD = cast<CXXMethodDecl>(GD.getDecl());
@ -486,7 +477,7 @@ public:
assert(submethods.size() == Methods.size() && "Method size mismatch!");
AppendMethods();
AppendMethodsToVtable();
// and then the non-virtual bases.
NonVirtualBases(RD, Layout, PrimaryBase, PrimaryBaseWasVirtual,
@ -851,9 +842,7 @@ bool VtableBuilder::OverrideMethod(GlobalDecl GD, llvm::Constant *m,
return false;
}
void VtableBuilder::AppendMethods() {
InstallThunks();
void VtableBuilder::AppendMethodsToVtable() {
for (unsigned i = 0, e = Methods.size(); i != e; ++i) {
GlobalDecl GD = Methods[i];
const CXXMethodDecl *MD = cast<CXXMethodDecl>(GD.getDecl());
@ -886,6 +875,9 @@ void VtableBuilder::AppendMethods() {
} else if (!ThisAdjustment.isEmpty()) {
// Build a "regular" thunk.
submethods[i] = CGM.BuildThunk(GD, Extern, ThisAdjustment);
} else if (MD->isPure()) {
// We have a pure virtual method.
submethods[i] = getPureVirtualFn();
}
}