diff options
author | Mike Stump <mrs@apple.com> | 2009-03-05 08:32:30 +0000 |
---|---|---|
committer | Mike Stump <mrs@apple.com> | 2009-03-05 08:32:30 +0000 |
commit | 00470a1c4c44c5ed26bad9a38b4d3904b02d7a28 (patch) | |
tree | b6a40a078a9a78a6123ae14a9da63e742bae8628 /lib/CodeGen/CodeGenFunction.h | |
parent | 7d22bf00dbabca86ba791f56a99e006181fa22dd (diff) |
prep work for copy/destroy helpers for block literals.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@66159 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/CodeGenFunction.h')
-rw-r--r-- | lib/CodeGen/CodeGenFunction.h | 12 |
1 files changed, 3 insertions, 9 deletions
diff --git a/lib/CodeGen/CodeGenFunction.h b/lib/CodeGen/CodeGenFunction.h index dec265aaf9..26fde8423c 100644 --- a/lib/CodeGen/CodeGenFunction.h +++ b/lib/CodeGen/CodeGenFunction.h @@ -271,8 +271,8 @@ public: llvm::Function *GenerateBlockFunction(const BlockExpr *BExpr, const BlockInfo& Info, uint64_t &Size, uint64_t &Align, - llvm::SmallVector<const Expr *, 8> &subBlockDeclRefDecls); - + llvm::SmallVector<const Expr *, 8> &subBlockDeclRefDecls, + bool &subBlockHasCopyDispose); llvm::Value *LoadBlockStruct(); @@ -288,6 +288,7 @@ public: uint64_t BlockOffset; /// BlockAlign - Maximal alignment needed for the Block expressed in bytes. uint64_t BlockAlign; + /// getBlockOffset - Allocate an offset for the ValueDecl from a /// BlockDeclRefExpr in a block literal (BlockExpr). uint64_t getBlockOffset(const BlockDeclRefExpr *E); @@ -298,13 +299,6 @@ public: llvm::Value *GetAddrOfBlockDecl(const BlockDeclRefExpr *E); const llvm::Type *BuildByRefType(QualType Ty, uint64_t Align); - bool BlockRequiresCopying(QualType Ty) { - if (Ty->isBlockPointerType()) - return true; - if (getContext().isObjCNSObjectType(Ty)) - return true; - return false; - } void GenerateCode(const FunctionDecl *FD, llvm::Function *Fn); |