aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2009-05-15 18:35:39 +0000
committerAnders Carlsson <andersca@mac.com>2009-05-15 18:35:39 +0000
commit167b824ce1947bf71ec8a71296daa2c54ebe58df (patch)
tree5e9e5d27e956c749ba401e03656ffc5ffd99c781
parentb70ccad30c7854f29c44d9bdd26c70754d28d3fe (diff)
A C++ member function always has either weak linkage (if it's inline or defined inline) or strong linkage (other cases).
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@71873 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/CodeGen/CodeGenModule.cpp8
-rw-r--r--test/CodeGenCXX/member-functions.cpp9
2 files changed, 16 insertions, 1 deletions
diff --git a/lib/CodeGen/CodeGenModule.cpp b/lib/CodeGen/CodeGenModule.cpp
index 706a97354e..2c966150df 100644
--- a/lib/CodeGen/CodeGenModule.cpp
+++ b/lib/CodeGen/CodeGenModule.cpp
@@ -241,6 +241,14 @@ void CodeGenModule::EmitAnnotations() {
static CodeGenModule::GVALinkage
GetLinkageForFunction(const FunctionDecl *FD, const LangOptions &Features) {
+ if (const CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(FD)) {
+ // C++ member functions defined inside the class are always inline.
+ if (MD->isInline() || !MD->isOutOfLineDefinition())
+ return CodeGenModule::GVA_CXXInline;
+
+ return CodeGenModule::GVA_StrongExternal;
+ }
+
// "static" functions get internal linkage.
if (FD->getStorageClass() == FunctionDecl::Static)
return CodeGenModule::GVA_Internal;
diff --git a/test/CodeGenCXX/member-functions.cpp b/test/CodeGenCXX/member-functions.cpp
index 84a18811d0..02c7e2c36d 100644
--- a/test/CodeGenCXX/member-functions.cpp
+++ b/test/CodeGenCXX/member-functions.cpp
@@ -26,14 +26,21 @@ struct S {
inline ~S() { }
+ // RUN: grep "define linkonce_odr void @_ZN1S9f_inline1Ev" %t &&
void f_inline1() { }
// RUN: grep "define linkonce_odr void @_ZN1S9f_inline2Ev" %t &&
inline void f_inline2() { }
- // RUN: grep "define internal void @_ZN1S1gEv" %t
+ // RUN: grep "define linkonce_odr void @_ZN1S1gEv" %t &&
static void g() { }
+
+ static void f();
};
+// RUN: grep "define void @_ZN1S1fEv" %t
+void S::f() {
+}
+
void test2() {
S s;