diff options
author | Anders Carlsson <andersca@mac.com> | 2009-05-15 18:35:39 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2009-05-15 18:35:39 +0000 |
commit | 167b824ce1947bf71ec8a71296daa2c54ebe58df (patch) | |
tree | 5e9e5d27e956c749ba401e03656ffc5ffd99c781 | |
parent | b70ccad30c7854f29c44d9bdd26c70754d28d3fe (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.cpp | 8 | ||||
-rw-r--r-- | test/CodeGenCXX/member-functions.cpp | 9 |
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; |