зеркало из https://github.com/microsoft/clang-1.git
Change mangleCXXVtable and mangleCXXRtti to take CXXRecordDecls instead of QualTypes.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@83793 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Родитель
bd785546c9
Коммит
fc3bf4d4d2
|
@ -1154,8 +1154,7 @@ llvm::Value *CodeGenFunction::GenerateVtable(const CXXRecordDecl *RD) {
|
||||||
llvm::SmallString<256> OutName;
|
llvm::SmallString<256> OutName;
|
||||||
llvm::raw_svector_ostream Out(OutName);
|
llvm::raw_svector_ostream Out(OutName);
|
||||||
QualType ClassTy;
|
QualType ClassTy;
|
||||||
ClassTy = getContext().getTagDeclType(RD);
|
mangleCXXVtable(CGM.getMangleContext(), RD, Out);
|
||||||
mangleCXXVtable(CGM.getMangleContext(), ClassTy, Out);
|
|
||||||
llvm::GlobalVariable::LinkageTypes linktype;
|
llvm::GlobalVariable::LinkageTypes linktype;
|
||||||
linktype = llvm::GlobalValue::WeakAnyLinkage;
|
linktype = llvm::GlobalValue::WeakAnyLinkage;
|
||||||
std::vector<llvm::Constant *> methods;
|
std::vector<llvm::Constant *> methods;
|
||||||
|
|
|
@ -25,9 +25,8 @@ llvm::Constant *CodeGenModule::GenerateRtti(const CXXRecordDecl *RD) {
|
||||||
|
|
||||||
llvm::SmallString<256> OutName;
|
llvm::SmallString<256> OutName;
|
||||||
llvm::raw_svector_ostream Out(OutName);
|
llvm::raw_svector_ostream Out(OutName);
|
||||||
QualType ClassTy;
|
mangleCXXRtti(getMangleContext(), RD, Out);
|
||||||
ClassTy = getContext().getTagDeclType(RD);
|
|
||||||
mangleCXXRtti(getMangleContext(), ClassTy, Out);
|
|
||||||
llvm::GlobalVariable::LinkageTypes linktype;
|
llvm::GlobalVariable::LinkageTypes linktype;
|
||||||
linktype = llvm::GlobalValue::WeakAnyLinkage;
|
linktype = llvm::GlobalValue::WeakAnyLinkage;
|
||||||
std::vector<llvm::Constant *> info;
|
std::vector<llvm::Constant *> info;
|
||||||
|
|
|
@ -51,8 +51,8 @@ namespace {
|
||||||
int64_t nv_r, int64_t v_r);
|
int64_t nv_r, int64_t v_r);
|
||||||
void mangleGuardVariable(const VarDecl *D);
|
void mangleGuardVariable(const VarDecl *D);
|
||||||
|
|
||||||
void mangleCXXVtable(QualType Type);
|
void mangleCXXVtable(const CXXRecordDecl *RD);
|
||||||
void mangleCXXRtti(QualType Type);
|
void mangleCXXRtti(const CXXRecordDecl *RD);
|
||||||
void mangleCXXCtor(const CXXConstructorDecl *D, CXXCtorType Type);
|
void mangleCXXCtor(const CXXConstructorDecl *D, CXXCtorType Type);
|
||||||
void mangleCXXDtor(const CXXDestructorDecl *D, CXXDtorType Type);
|
void mangleCXXDtor(const CXXDestructorDecl *D, CXXDtorType Type);
|
||||||
|
|
||||||
|
@ -198,16 +198,16 @@ void CXXNameMangler::mangleCXXDtor(const CXXDestructorDecl *D,
|
||||||
mangle(D);
|
mangle(D);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CXXNameMangler::mangleCXXVtable(QualType T) {
|
void CXXNameMangler::mangleCXXVtable(const CXXRecordDecl *RD) {
|
||||||
// <special-name> ::= TV <type> # virtual table
|
// <special-name> ::= TV <type> # virtual table
|
||||||
Out << "_ZTV";
|
Out << "_ZTV";
|
||||||
mangleType(T);
|
mangleName(RD);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CXXNameMangler::mangleCXXRtti(QualType T) {
|
void CXXNameMangler::mangleCXXRtti(const CXXRecordDecl *RD) {
|
||||||
// <special-name> ::= TI <type> # typeinfo structure
|
// <special-name> ::= TI <type> # typeinfo structure
|
||||||
Out << "_ZTI";
|
Out << "_ZTI";
|
||||||
mangleType(T);
|
mangleName(RD);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CXXNameMangler::mangleGuardVariable(const VarDecl *D) {
|
void CXXNameMangler::mangleGuardVariable(const VarDecl *D) {
|
||||||
|
@ -1414,18 +1414,18 @@ namespace clang {
|
||||||
os.flush();
|
os.flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
void mangleCXXVtable(MangleContext &Context, QualType Type,
|
void mangleCXXVtable(MangleContext &Context, const CXXRecordDecl *RD,
|
||||||
llvm::raw_ostream &os) {
|
llvm::raw_ostream &os) {
|
||||||
CXXNameMangler Mangler(Context, os);
|
CXXNameMangler Mangler(Context, os);
|
||||||
Mangler.mangleCXXVtable(Type);
|
Mangler.mangleCXXVtable(RD);
|
||||||
|
|
||||||
os.flush();
|
os.flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
void mangleCXXRtti(MangleContext &Context, QualType Type,
|
void mangleCXXRtti(MangleContext &Context, const CXXRecordDecl *RD,
|
||||||
llvm::raw_ostream &os) {
|
llvm::raw_ostream &os) {
|
||||||
CXXNameMangler Mangler(Context, os);
|
CXXNameMangler Mangler(Context, os);
|
||||||
Mangler.mangleCXXRtti(Type);
|
Mangler.mangleCXXRtti(RD);
|
||||||
|
|
||||||
os.flush();
|
os.flush();
|
||||||
}
|
}
|
||||||
|
|
|
@ -63,8 +63,10 @@ namespace clang {
|
||||||
llvm::raw_ostream &os);
|
llvm::raw_ostream &os);
|
||||||
void mangleGuardVariable(MangleContext &Context, const VarDecl *D,
|
void mangleGuardVariable(MangleContext &Context, const VarDecl *D,
|
||||||
llvm::raw_ostream &os);
|
llvm::raw_ostream &os);
|
||||||
void mangleCXXVtable(MangleContext &Context, QualType T, llvm::raw_ostream &os);
|
void mangleCXXVtable(MangleContext &Context, const CXXRecordDecl *RD,
|
||||||
void mangleCXXRtti(MangleContext &Context, QualType T, llvm::raw_ostream &os);
|
llvm::raw_ostream &os);
|
||||||
|
void mangleCXXRtti(MangleContext &Context, const CXXRecordDecl *RD,
|
||||||
|
llvm::raw_ostream &os);
|
||||||
void mangleCXXCtor(MangleContext &Context, const CXXConstructorDecl *D,
|
void mangleCXXCtor(MangleContext &Context, const CXXConstructorDecl *D,
|
||||||
CXXCtorType Type, llvm::raw_ostream &os);
|
CXXCtorType Type, llvm::raw_ostream &os);
|
||||||
void mangleCXXDtor(MangleContext &Context, const CXXDestructorDecl *D,
|
void mangleCXXDtor(MangleContext &Context, const CXXDestructorDecl *D,
|
||||||
|
|
Загрузка…
Ссылка в новой задаче