diff options
author | Chris Lattner <sabre@nondot.org> | 2009-05-12 21:02:27 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2009-05-12 21:02:27 +0000 |
commit | d035ebda2f798dca978715d5c53d9d8e8ae69a6d (patch) | |
tree | 3ec838eefe79e3539b15ea1b26a6b4c7a3ac538f | |
parent | eb7466d24a8b2bc7e6495fc97060b831fc8a8ffe (diff) | |
download | bcm5719-llvm-d035ebda2f798dca978715d5c53d9d8e8ae69a6d.tar.gz bcm5719-llvm-d035ebda2f798dca978715d5c53d9d8e8ae69a6d.zip |
add an initial stab at emitting deferred c++ inline functions. This handles static
functions and methods declared inline, but not ctors/dtors or methods not declared
inline (apparently my previous patch wasn't good enough).
llvm-svn: 71591
-rw-r--r-- | clang/lib/CodeGen/CodeGenModule.cpp | 9 | ||||
-rw-r--r-- | clang/test/CodeGenCXX/member-functions.cpp | 28 |
2 files changed, 35 insertions, 2 deletions
diff --git a/clang/lib/CodeGen/CodeGenModule.cpp b/clang/lib/CodeGen/CodeGenModule.cpp index c2dc629680c..6e4a67b917b 100644 --- a/clang/lib/CodeGen/CodeGenModule.cpp +++ b/clang/lib/CodeGen/CodeGenModule.cpp @@ -606,6 +606,15 @@ llvm::Constant *CodeGenModule::GetOrCreateLLVMFunction(const char *MangledName, // list, and remove it from DeferredDecls (since we don't need it anymore). DeferredDeclsToEmit.push_back(DDI->second); DeferredDecls.erase(DDI); + } else if (D && D->isThisDeclarationADefinition() && MayDeferGeneration(D)) { + // If this the first reference to a C++ inline function in a class, queue up + // the deferred function body for emission. These are not seen as + // top-level declarations. + // FIXME: Make this work for ctor/dtors. We need to pass down a full + // GlobalDecl instead of just a FunctionDecl. + if (!isa<CXXConstructorDecl>(D) && + !isa<CXXDestructorDecl>(D)) + DeferredDeclsToEmit.push_back(GlobalDecl(D)); } // This function doesn't have a complete type (for example, the return diff --git a/clang/test/CodeGenCXX/member-functions.cpp b/clang/test/CodeGenCXX/member-functions.cpp index 9cdab0a6624..83278909eac 100644 --- a/clang/test/CodeGenCXX/member-functions.cpp +++ b/clang/test/CodeGenCXX/member-functions.cpp @@ -8,12 +8,36 @@ struct C { void C::f() { } -void f() { +void test1() { C c; // RUN: grep "call void @_ZN1C1fEv" %t | count 1 && c.f(); -// RUN: grep "call void (.struct.C\*, i32, ...)\* @_ZN1C1gEiz" %t | count 1 +// RUN: grep "call void (.struct.C\*, i32, ...)\* @_ZN1C1gEiz" %t | count 1 && c.g(1, 2, 3); } + + +struct S { + S() { } + ~S() { } + + + void f_inline1() { } + // RUN: grep "define linkonce_odr void @_ZN1S9f_inline2Ev" %t && + inline void f_inline2() { } + + // RUN: grep "define internal void @_ZN1S1gEv" %t + static void g() { } +}; + +void test2() { + S s; + + s.f_inline1(); + s.f_inline2(); + + S::g(); + +} |