summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2011-02-15 18:11:42 +0000
committerDouglas Gregor <dgregor@apple.com>2011-02-15 18:11:42 +0000
commite061015de8915ba7a61784b930eb1cc374f15060 (patch)
treeebb8f6d4c2ae70cd004b41af9eb4a1fb1a749567
parent5e38f35fe38bba2281eb5730df3a7e4c0248cf94 (diff)
downloadbcm5719-llvm-e061015de8915ba7a61784b930eb1cc374f15060.tar.gz
bcm5719-llvm-e061015de8915ba7a61784b930eb1cc374f15060.zip
Emit in-class member function definitions that are marked
"used". Fixes <rdar://problem/8684363>. llvm-svn: 125579
-rw-r--r--clang/lib/CodeGen/ModuleBuilder.cpp12
-rw-r--r--clang/test/CodeGenCXX/attr-used.cpp9
2 files changed, 21 insertions, 0 deletions
diff --git a/clang/lib/CodeGen/ModuleBuilder.cpp b/clang/lib/CodeGen/ModuleBuilder.cpp
index 6d9d2770c7c..d41d3ac268a 100644
--- a/clang/lib/CodeGen/ModuleBuilder.cpp
+++ b/clang/lib/CodeGen/ModuleBuilder.cpp
@@ -71,6 +71,18 @@ namespace {
/// (because these can be defined in declspecs).
virtual void HandleTagDeclDefinition(TagDecl *D) {
Builder->UpdateCompletedType(D);
+
+ // In C++, we may have member functions that need to be emitted at this
+ // point.
+ if (Ctx->getLangOptions().CPlusPlus && !D->isDependentContext()) {
+ for (DeclContext::decl_iterator M = D->decls_begin(),
+ MEnd = D->decls_end();
+ M != MEnd; ++M)
+ if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(*M))
+ if (Method->isThisDeclarationADefinition() &&
+ Method->hasAttr<UsedAttr>())
+ Builder->EmitTopLevelDecl(Method);
+ }
}
virtual void HandleTranslationUnit(ASTContext &Ctx) {
diff --git a/clang/test/CodeGenCXX/attr-used.cpp b/clang/test/CodeGenCXX/attr-used.cpp
new file mode 100644
index 00000000000..26109e7c630
--- /dev/null
+++ b/clang/test/CodeGenCXX/attr-used.cpp
@@ -0,0 +1,9 @@
+// RUN: %clang_cc1 -emit-llvm -o - %s | FileCheck %s
+
+// <rdar://problem/8684363>: clang++ not respecting __attribute__((used)) on destructors
+struct X0 {
+ // CHECK: define linkonce_odr void @_ZN2X0C1Ev
+ __attribute__((used)) X0() {}
+ // CHECK: define linkonce_odr void @_ZN2X0D1Ev
+ __attribute__((used)) ~X0() {}
+};
OpenPOWER on IntegriCloud