diff options
| author | Fariborz Jahanian <fjahanian@apple.com> | 2012-04-10 00:08:18 +0000 |
|---|---|---|
| committer | Fariborz Jahanian <fjahanian@apple.com> | 2012-04-10 00:08:18 +0000 |
| commit | 2c00acd67f80d88611646f224b37c348f8435d50 (patch) | |
| tree | dd63f8f1f8afd8463721010d7023fdaad048c206 | |
| parent | ec96cd0690e7f28769fbc2bf7e2c2ba90e84178c (diff) | |
| download | bcm5719-llvm-2c00acd67f80d88611646f224b37c348f8435d50.tar.gz bcm5719-llvm-2c00acd67f80d88611646f224b37c348f8435d50.zip | |
objective-c modern translator: rewriting specific
implicit casts which is needed to produce good c++
code. // rdar://11202764
llvm-svn: 154360
| -rw-r--r-- | clang/lib/Rewrite/RewriteModernObjC.cpp | 22 | ||||
| -rw-r--r-- | clang/test/Rewriter/objc-modern-implicit-cast.mm | 33 |
2 files changed, 55 insertions, 0 deletions
diff --git a/clang/lib/Rewrite/RewriteModernObjC.cpp b/clang/lib/Rewrite/RewriteModernObjC.cpp index a9fe8cecd13..162f7a52894 100644 --- a/clang/lib/Rewrite/RewriteModernObjC.cpp +++ b/clang/lib/Rewrite/RewriteModernObjC.cpp @@ -330,6 +330,7 @@ namespace { Stmt *RewriteBreakStmt(BreakStmt *S); Stmt *RewriteContinueStmt(ContinueStmt *S); void RewriteCastExpr(CStyleCastExpr *CE); + void RewriteImplicitCastObjCExpr(CastExpr *IE); void RewriteLinkageSpec(LinkageSpecDecl *LSD); // Block rewriting. @@ -4459,6 +4460,24 @@ void RewriteModernObjC::RewriteCastExpr(CStyleCastExpr *CE) { return; } +void RewriteModernObjC::RewriteImplicitCastObjCExpr(CastExpr *IC) { + CastKind CastKind = IC->getCastKind(); + + if (CastKind == CK_BlockPointerToObjCPointerCast) { + CStyleCastExpr * CastExpr = + NoTypeInfoCStyleCastExpr(Context, IC->getType(), CK_BitCast, IC); + ReplaceStmt(IC, CastExpr); + } + else if (CastKind == CK_AnyPointerToBlockPointerCast) { + QualType BlockT = IC->getType(); + (void)convertBlockPointerToFunctionPointer(BlockT); + CStyleCastExpr * CastExpr = + NoTypeInfoCStyleCastExpr(Context, BlockT, CK_BitCast, IC); + ReplaceStmt(IC, CastExpr); + } + return; +} + void RewriteModernObjC::RewriteBlockPointerFunctionArgs(FunctionDecl *FD) { SourceLocation DeclLoc = FD->getLocation(); unsigned parenCount = 0; @@ -5336,6 +5355,9 @@ Stmt *RewriteModernObjC::RewriteFunctionBodyOrGlobalInitializer(Stmt *S) { if (CStyleCastExpr *CE = dyn_cast<CStyleCastExpr>(S)) { RewriteCastExpr(CE); } + if (ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(S)) { + RewriteImplicitCastObjCExpr(ICE); + } #if 0 if (ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(S)) { CastExpr *Replacement = new (Context) CastExpr(ICE->getType(), diff --git a/clang/test/Rewriter/objc-modern-implicit-cast.mm b/clang/test/Rewriter/objc-modern-implicit-cast.mm new file mode 100644 index 00000000000..e6121991e56 --- /dev/null +++ b/clang/test/Rewriter/objc-modern-implicit-cast.mm @@ -0,0 +1,33 @@ +// RUN: %clang_cc1 -x objective-c++ -fblocks -fms-extensions -rewrite-objc %s -o %t-rw.cpp +// RUN: %clang_cc1 -fsyntax-only -fblocks -Wno-address-of-temporary -D"Class=void*" -D"id=void*" -D"SEL=void*" -D"__declspec(X)=" %t-rw.cpp +// rdar://11202764 + +typedef void(^BL)(void); + +id return_id(void(^block)(void)) { + return block; +} + +BL return_block(id obj) { + return obj; +} + +int main() +{ + void(^block)(void); + id obj; + block = obj; // AnyPointerToBlockPointerCast + obj = block; // BlockPointerToObjCPointerCast + + id obj1 = block; + + void(^block1)(void) = obj1; + + return_id(block1); + + return_id(obj1); + + return_block(block1); + + return_block(obj1); +} |

