aboutsummaryrefslogtreecommitdiff
path: root/lib/CodeGen/Mangle.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'lib/CodeGen/Mangle.cpp')
-rw-r--r--lib/CodeGen/Mangle.cpp23
1 files changed, 22 insertions, 1 deletions
diff --git a/lib/CodeGen/Mangle.cpp b/lib/CodeGen/Mangle.cpp
index e07c38fd11..c07d9039c0 100644
--- a/lib/CodeGen/Mangle.cpp
+++ b/lib/CodeGen/Mangle.cpp
@@ -59,6 +59,8 @@ namespace {
bool mangleSubstitution(QualType T);
bool mangleSubstitution(uintptr_t Ptr);
+ bool mangleStandardSubstitution(const NamedDecl *ND);
+
void addSubstitution(const NamedDecl *ND) {
addSubstitution(reinterpret_cast<uintptr_t>(ND));
}
@@ -1070,8 +1072,11 @@ void CXXNameMangler::mangleTemplateArgument(const TemplateArgument &A) {
// <substitution> ::= S <seq-id> _
// ::= S_
-
bool CXXNameMangler::mangleSubstitution(const NamedDecl *ND) {
+ // Try one of the standard substitutions first.
+ if (mangleStandardSubstitution(ND))
+ return true;
+
return mangleSubstitution(reinterpret_cast<uintptr_t>(ND));
}
@@ -1120,6 +1125,22 @@ bool CXXNameMangler::mangleSubstitution(uintptr_t Ptr) {
return true;
}
+bool CXXNameMangler::mangleStandardSubstitution(const NamedDecl *ND) {
+ // <substitution> ::= St # ::std::
+
+ const NamespaceDecl *NS = dyn_cast<NamespaceDecl>(ND);
+ if (!NS)
+ return false;
+ if (!NS->getParent()->isTranslationUnit())
+ return false;
+
+ if (!NS->getOriginalNamespace()->getIdentifier()->isStr("std"))
+ return false;
+
+ Out << "St";
+ return true;
+}
+
void CXXNameMangler::addSubstitution(QualType T) {
if (!T.getCVRQualifiers()) {
if (const RecordType *RT = T->getAs<RecordType>()) {