summaryrefslogtreecommitdiffstats
path: root/clang/lib/CodeGen/Mangle.cpp
diff options
context:
space:
mode:
authorEli Friedman <eli.friedman@gmail.com>2010-07-18 20:49:59 +0000
committerEli Friedman <eli.friedman@gmail.com>2010-07-18 20:49:59 +0000
commitf8340deacd3f79b0e3c6bf60fcb8653cf683dd2f (patch)
tree0218c0d90e462a7fada61fd15c92283f6d6bd736 /clang/lib/CodeGen/Mangle.cpp
parent40a564f09f5e6878290ba0ad8b45f114b1df51b9 (diff)
downloadbcm5719-llvm-f8340deacd3f79b0e3c6bf60fcb8653cf683dd2f.tar.gz
bcm5719-llvm-f8340deacd3f79b0e3c6bf60fcb8653cf683dd2f.zip
Fix mangling for static member variables of classes inside an extern "C"
linkage specification. Not sure if this is the ideal fix, but I'm reasonably sure it's correct vs. gcc. llvm-svn: 108656
Diffstat (limited to 'clang/lib/CodeGen/Mangle.cpp')
-rw-r--r--clang/lib/CodeGen/Mangle.cpp4
1 files changed, 4 insertions, 0 deletions
diff --git a/clang/lib/CodeGen/Mangle.cpp b/clang/lib/CodeGen/Mangle.cpp
index 58b0246e363..f408849e95e 100644
--- a/clang/lib/CodeGen/Mangle.cpp
+++ b/clang/lib/CodeGen/Mangle.cpp
@@ -304,6 +304,10 @@ bool MangleContext::shouldMangleDeclName(const NamedDecl *D) {
return false;
}
+ // Class members are always mangled.
+ if (D->getDeclContext()->isRecord())
+ return true;
+
// C functions and "main" are not mangled.
if ((FD && FD->isMain()) || isInCLinkageSpecification(D))
return false;
OpenPOWER on IntegriCloud