From: Anders Carlsson Date: Thu, 8 Oct 2009 17:20:26 +0000 (+0000) Subject: Mangle std::basic_ostream> as So. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=8f8fd8ea7e5c5d04f95a3cf4af95aa93225bc2b4;p=clang Mangle std::basic_ostream> as So. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@83557 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/Mangle.cpp b/lib/CodeGen/Mangle.cpp index aa017c9207..9468520592 100644 --- a/lib/CodeGen/Mangle.cpp +++ b/lib/CodeGen/Mangle.cpp @@ -1291,6 +1291,24 @@ bool CXXNameMangler::mangleStandardSubstitution(const NamedDecl *ND) { Out << "Ss"; return true; } + + // ::= So # ::std::basic_ostream > + if (SD->getIdentifier()->isStr("basic_ostream")) { + const TemplateArgumentList &TemplateArgs = SD->getTemplateArgs(); + + if (TemplateArgs.size() != 2) + return false; + + if (!isCharType(TemplateArgs[0].getAsType())) + return false; + + if (!isCharSpecialization(TemplateArgs[1].getAsType(), "char_traits")) + return false; + + Out << "So"; + return true; + } } return false; } diff --git a/test/CodeGenCXX/mangle-subst-std.cpp b/test/CodeGenCXX/mangle-subst-std.cpp index 6a81c6d04b..fbce204512 100644 --- a/test/CodeGenCXX/mangle-subst-std.cpp +++ b/test/CodeGenCXX/mangle-subst-std.cpp @@ -9,24 +9,31 @@ namespace std { }; namespace std { - template struct allocator { }; + template struct allocator { }; } // CHECK: define void @_Z1fSaIcESaIiE void f(std::allocator, std::allocator) { } namespace std { - template struct basic_string { }; + template struct basic_string { }; } // CHECK: define void @_Z1fSbIcciE void f(std::basic_string) { } namespace std { - template struct char_traits { }; + template struct char_traits { }; typedef std::basic_string, std::allocator > string; } // CHECK: _Z1fSs void f(std::string) { } + +namespace std { + template struct basic_ostream { }; +} + +// CHECK: _Z1fSo +void f(std::basic_ostream >) { }