]> granicus.if.org Git - clang/commitdiff
Implement mangling of declarations inside functions.
authorAnders Carlsson <andersca@mac.com>
Thu, 2 Apr 2009 16:24:45 +0000 (16:24 +0000)
committerAnders Carlsson <andersca@mac.com>
Thu, 2 Apr 2009 16:24:45 +0000 (16:24 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@68321 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/Mangle.cpp
test/CodeGenCXX/mangle.cpp

index 6e62fcfc2e67ccafcf0fc14466fdbc0bdfe4e4a8..3e685e6b1722e921afc4af5f80c57406599eb490 100644 (file)
@@ -42,6 +42,7 @@ namespace {
     void mangleName(const NamedDecl *ND);
     void mangleUnqualifiedName(const NamedDecl *ND);
     void mangleSourceName(const IdentifierInfo *II);
+    void mangleLocalName(const NamedDecl *ND);
     void mangleNestedName(const NamedDecl *ND);
     void manglePrefix(const DeclContext *DC);
     void mangleOperatorName(OverloadedOperatorKind OO, unsigned Arity);
@@ -149,9 +150,10 @@ void CXXNameMangler::mangleName(const NamedDecl *ND) {
   else if (isStdNamespace(ND->getDeclContext())) {
     Out << "St";
     mangleUnqualifiedName(ND);
-  } else {
+  } else if (isa<FunctionDecl>(ND->getDeclContext()))
+    mangleLocalName(ND);
+  else
     mangleNestedName(ND);
-  }
 }
 
 void CXXNameMangler::mangleUnqualifiedName(const NamedDecl *ND) {
@@ -226,6 +228,16 @@ void CXXNameMangler::mangleNestedName(const NamedDecl *ND) {
   Out << 'E';
 }
 
+void CXXNameMangler::mangleLocalName(const NamedDecl *ND) {
+  // <local-name> := Z <function encoding> E <entity name> [<discriminator>]
+  //              := Z <function encoding> E s [<discriminator>]
+  // <discriminator> := _ <non-negative number> 
+  Out << 'Z';
+  mangleFunctionEncoding(cast<FunctionDecl>(ND->getDeclContext()));
+  Out << 'E';
+  mangleSourceName(ND->getIdentifier());
+}
+
 void CXXNameMangler::manglePrefix(const DeclContext *DC) {
   //  <prefix> ::= <prefix> <unqualified-name>
   //           ::= <template-prefix> <template-args>
index e9a76c93f08e265ed1de62bf941ff467b7a7cd59..f608a22f0323adc5b95f2419b3503594a2c3fa6d 100644 (file)
@@ -39,5 +39,8 @@ extern "C" { namespace N { void unmangled_function() { } } }
 // RUN: grep unmangled_variable %t | count 1 &&
 extern "C" { namespace N { int unmangled_variable; } }
 
-// RUN: grep _ZN1N1iE %t | count 1
+// RUN: grep _ZN1N1iE %t | count 1 &&
 namespace N { int i; }
+
+// RUN: grep _ZZN1N1fEiiE1b %t | count 2
+namespace N { int f(int, int) { static int b; return b; } }