diff options
author | Anders Carlsson <andersca@mac.com> | 2009-02-24 04:19:41 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2009-02-24 04:19:41 +0000 |
commit | 911e0af45196b15e9dd8557ca9ebf00fb01c4fdc (patch) | |
tree | bb68be8c55d25c5dc47074382202773ade5017da /lib/CodeGen | |
parent | 3d5e06254909d5a58cc5fcff4ebeef1f3faebaf9 (diff) |
Pass the CodeGenModule object to GenerateBlockFunction, instead of *this (which will call the copy constructor).
Also, since we're creating a new CodeGenFunction object for each block function, we don't need to clear the BreakContinueStack.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@65371 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen')
-rw-r--r-- | lib/CodeGen/CGBlocks.cpp | 7 |
1 files changed, 1 insertions, 6 deletions
diff --git a/lib/CodeGen/CGBlocks.cpp b/lib/CodeGen/CGBlocks.cpp index 5c09e4b2d5..163046ee58 100644 --- a/lib/CodeGen/CGBlocks.cpp +++ b/lib/CodeGen/CGBlocks.cpp @@ -154,7 +154,7 @@ llvm::Constant *CodeGenFunction::BuildBlockLiteralTmp(const BlockExpr *BE) { BlockInfo Info(0, Name); uint64_t subBlockSize; llvm::Function *Fn - = CodeGenFunction(*this).GenerateBlockFunction(BE, Info, subBlockSize); + = CodeGenFunction(CGM).GenerateBlockFunction(BE, Info, subBlockSize); Elts.push_back(Fn); // __descriptor @@ -412,11 +412,6 @@ llvm::Function *CodeGenFunction::GenerateBlockFunction(const BlockExpr *Expr, const BlockDecl *BD = Expr->getBlockDecl(); - // FIXME: there are tons of variables in CGF that are copied, we probably - // don't want many of them, any of them. When we trim that, this can go away. - // Help ensure no control flow in or out of the block. - BreakContinueStack.clear(); - // FIXME: This leaks ImplicitParamDecl *SelfDecl = ImplicitParamDecl::Create(getContext(), 0, |