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
This commit is contained in:
Chris Lattner
2009-05-12 21:02:27 +00:00
parent eb7466d24a
commit d035ebda2f
2 changed files with 35 additions and 2 deletions

View File

@@ -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