зеркало из https://github.com/microsoft/clang-1.git
It's OK to try to emit a vtable definition more than once. Fixes PR5697.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@90751 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Родитель
b13e357dac
Коммит
d58987c67d
|
@ -1400,8 +1400,13 @@ CGVtableInfo::GenerateVTT(llvm::GlobalVariable::LinkageTypes Linkage,
|
||||||
|
|
||||||
void CGVtableInfo::GenerateClassData(llvm::GlobalVariable::LinkageTypes Linkage,
|
void CGVtableInfo::GenerateClassData(llvm::GlobalVariable::LinkageTypes Linkage,
|
||||||
const CXXRecordDecl *RD) {
|
const CXXRecordDecl *RD) {
|
||||||
assert(!Vtables.count(RD) && "Vtable has already been generated!");
|
llvm::GlobalVariable *&Vtable = Vtables[RD];
|
||||||
Vtables[RD] = GenerateVtable(Linkage, /*GenerateDefinition=*/true, RD, RD, 0);
|
if (Vtable) {
|
||||||
|
assert(Vtable->getInitializer() && "Vtable doesn't have a definition!");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
Vtable = GenerateVtable(Linkage, /*GenerateDefinition=*/true, RD, RD, 0);
|
||||||
|
|
||||||
CGM.GenerateRTTI(RD);
|
CGM.GenerateRTTI(RD);
|
||||||
GenerateVTT(Linkage, RD);
|
GenerateVTT(Linkage, RD);
|
||||||
|
|
|
@ -0,0 +1,15 @@
|
||||||
|
// RUN: clang-cc %s -triple=x86_64-apple-darwin10 -emit-llvm -o - | FileCheck %s
|
||||||
|
// PR5697
|
||||||
|
namespace PR5697 {
|
||||||
|
struct A {
|
||||||
|
virtual void f() { }
|
||||||
|
A();
|
||||||
|
A(int);
|
||||||
|
};
|
||||||
|
|
||||||
|
// A does not have a key function, so the first constructor we emit should
|
||||||
|
// cause the vtable to be defined (without assertions.)
|
||||||
|
// CHECK: @_ZTVN6PR56971AE = weak_odr constant
|
||||||
|
A::A() { }
|
||||||
|
A::A(int) { }
|
||||||
|
}
|
Загрузка…
Ссылка в новой задаче