diff options
author | Anders Carlsson <andersca@mac.com> | 2009-09-22 20:33:31 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2009-09-22 20:33:31 +0000 |
commit | 1d3b6f62dfe03256b0becc5c8ecfcd606df1fa6a (patch) | |
tree | a2bada6bce4438d343824131d98a80eb24dd02d6 /clang/lib/CodeGen/Mangle.cpp | |
parent | f0647a5fbcebfb16896a5e6d29d1cfd53837608b (diff) | |
download | bcm5719-llvm-1d3b6f62dfe03256b0becc5c8ecfcd606df1fa6a.tar.gz bcm5719-llvm-1d3b6f62dfe03256b0becc5c8ecfcd606df1fa6a.zip |
CXXMethodDecls should always be mangled, even if they are inside an extern "C" block. Fixes PR5017.
llvm-svn: 82567
Diffstat (limited to 'clang/lib/CodeGen/Mangle.cpp')
-rw-r--r-- | clang/lib/CodeGen/Mangle.cpp | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/clang/lib/CodeGen/Mangle.cpp b/clang/lib/CodeGen/Mangle.cpp index 5a994d2234b..878f13d516d 100644 --- a/clang/lib/CodeGen/Mangle.cpp +++ b/clang/lib/CodeGen/Mangle.cpp @@ -131,7 +131,7 @@ bool CXXNameMangler::mangleFunctionDecl(const FunctionDecl *FD) { return false; // No name mangling in a C linkage specification. - if (isInCLinkageSpecification(FD)) + if (!isa<CXXMethodDecl>(FD) && isInCLinkageSpecification(FD)) return false; } @@ -502,6 +502,9 @@ void CXXNameMangler::manglePrefix(const DeclContext *DC) { // ::= <substitution> // FIXME: We only handle mangling of namespaces and classes at the moment. + while (isa<LinkageSpecDecl>(DC)) + DC = DC->getParent(); + if (DC->isTranslationUnit()) return; |