diff options
author | Fariborz Jahanian <fjahanian@apple.com> | 2010-02-24 01:25:40 +0000 |
---|---|---|
committer | Fariborz Jahanian <fjahanian@apple.com> | 2010-02-24 01:25:40 +0000 |
commit | 86aa9fdbb542300059977348518eaf3067c508fd (patch) | |
tree | 6811c1e591375a6e7db13b397108b7bbd30b6a91 | |
parent | 87260c7eabf88eb2009ba2ba20150cd897483241 (diff) |
Fix rewriting of a method when return type is
a block pointer type. Fixes radar 7682149.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@97008 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Frontend/RewriteObjC.cpp | 4 | ||||
-rw-r--r-- | test/Rewriter/rewrite-block-pointer.mm | 25 |
2 files changed, 29 insertions, 0 deletions
diff --git a/lib/Frontend/RewriteObjC.cpp b/lib/Frontend/RewriteObjC.cpp index 0156d1da91..521abf489b 100644 --- a/lib/Frontend/RewriteObjC.cpp +++ b/lib/Frontend/RewriteObjC.cpp @@ -2815,6 +2815,10 @@ Stmt *RewriteObjC::SynthMessageExpr(ObjCMessageExpr *Exp, } returnType = OMD->getResultType()->isObjCQualifiedIdType() ? Context->getObjCIdType() : OMD->getResultType(); + if (isTopLevelBlockPointerType(returnType)) { + const BlockPointerType *BPT = returnType->getAs<BlockPointerType>(); + returnType = Context->getPointerType(BPT->getPointeeType()); + } } else { returnType = Context->getObjCIdType(); } diff --git a/test/Rewriter/rewrite-block-pointer.mm b/test/Rewriter/rewrite-block-pointer.mm index 4a4fa34708..8698b93c18 100644 --- a/test/Rewriter/rewrite-block-pointer.mm +++ b/test/Rewriter/rewrite-block-pointer.mm @@ -3,6 +3,7 @@ // radar 7638400 typedef void * id; +void *sel_registerName(const char *); @interface X @end @@ -33,3 +34,27 @@ void *_Block_copy(const void *aBlock); void x(void (^block)(void)) { block = ((__typeof(block))_Block_copy((const void *)(block))); } + +// radar 7682149 +@interface Y { +@private + id _private; +} +- (void (^)(void))f; +@end + +typedef void (^void_block_t)(void); + +@interface YY { + void_block_t __completion; +} +@property (copy) void_block_t f; +@end + +@implementation Y +- (void (^)(void))f { + return [_private f]; +} + +@end + |