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 | f1ee68710ae8ca93a35ab11995ed5df321ade9ec (patch) | |
tree | 8a5039d6b1f8ea46fbf7430c3448f1a73e8aaa8b /lib/Rewrite/RewriteModernObjC.cpp | |
parent | c5151543236bd213b8595a079cf9b1d26de4eeb1 (diff) |
objective-c modern translator: rewriting specific
implicit casts which is needed to produce good c++
code. // rdar://11202764
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@154360 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Rewrite/RewriteModernObjC.cpp')
-rw-r--r-- | lib/Rewrite/RewriteModernObjC.cpp | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/lib/Rewrite/RewriteModernObjC.cpp b/lib/Rewrite/RewriteModernObjC.cpp index a9fe8cecd1..162f7a5289 100644 --- a/lib/Rewrite/RewriteModernObjC.cpp +++ b/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(), |