diff options
| author | Fariborz Jahanian <fjahanian@apple.com> | 2012-02-24 17:35:35 +0000 |
|---|---|---|
| committer | Fariborz Jahanian <fjahanian@apple.com> | 2012-02-24 17:35:35 +0000 |
| commit | dd5a59baedc99d2c2058b6c3b59f7860e45cdcc5 (patch) | |
| tree | 8860e778f1e8ac189d1c9a2ff00452c19b6fcaa0 /clang | |
| parent | e8dd130762b7f8c1892371cf526702cafd9fcbe0 (diff) | |
| download | bcm5719-llvm-dd5a59baedc99d2c2058b6c3b59f7860e45cdcc5.tar.gz bcm5719-llvm-dd5a59baedc99d2c2058b6c3b59f7860e45cdcc5.zip | |
objc modern translator. Fixes writing of block pointer ivar access.
llvm-svn: 151371
Diffstat (limited to 'clang')
| -rw-r--r-- | clang/lib/Rewrite/RewriteModernObjC.cpp | 4 | ||||
| -rw-r--r-- | clang/test/Rewriter/rewrite-modern-block-ivar-call.mm | 17 |
2 files changed, 20 insertions, 1 deletions
diff --git a/clang/lib/Rewrite/RewriteModernObjC.cpp b/clang/lib/Rewrite/RewriteModernObjC.cpp index 63dfa561d3a..403ccd9c12d 100644 --- a/clang/lib/Rewrite/RewriteModernObjC.cpp +++ b/clang/lib/Rewrite/RewriteModernObjC.cpp @@ -6469,8 +6469,10 @@ Stmt *RewriteModernObjC::RewriteObjCIvarRefExpr(ObjCIvarRefExpr *IV) { ParenExpr *PE = new (Context) ParenExpr(SourceLocation(), SourceLocation(), addExpr); + QualType IvarT = D->getType(); + convertBlockPointerToFunctionPointer(IvarT); + QualType castT = Context->getPointerType(IvarT); - QualType castT = Context->getPointerType(D->getType()); castExpr = NoTypeInfoCStyleCastExpr(Context, castT, CK_BitCast, diff --git a/clang/test/Rewriter/rewrite-modern-block-ivar-call.mm b/clang/test/Rewriter/rewrite-modern-block-ivar-call.mm new file mode 100644 index 00000000000..0fe2d543ee0 --- /dev/null +++ b/clang/test/Rewriter/rewrite-modern-block-ivar-call.mm @@ -0,0 +1,17 @@ +// RUN: %clang_cc1 -E %s -o %t.m +// RUN: %clang_cc1 -fblocks -rewrite-objc -fms-extensions %t.m -o %t-rw.cpp +// RUN: FileCheck --input-file=%t-rw.cpp %s +// RUN: %clang_cc1 -fsyntax-only -Wno-address-of-temporary -D"Class=void*" -D"id=void*" -D"SEL=void*" -D"__declspec(X)=" %t-rw.cpp + +@interface Foo { + void (^_block)(void); +} +@end + +@implementation Foo +- (void)bar { + _block(); +} +@end + +// CHECK: ((void (*)(struct __block_impl *))((struct __block_impl *)(*(void (**)(void))((char *)self + OBJC_IVAR_$_Foo__block)))->FuncPtr)((struct __block_impl *)(*(void (**)(void))((char *)self + OBJC_IVAR_$_Foo__block))); |

