]> granicus.if.org Git - clang/commitdiff
Patch to allow C-style cast from 'void *' to block pointer type.
authorFariborz Jahanian <fjahanian@apple.com>
Fri, 11 Dec 2009 22:40:48 +0000 (22:40 +0000)
committerFariborz Jahanian <fjahanian@apple.com>
Fri, 11 Dec 2009 22:40:48 +0000 (22:40 +0000)
(fixes radar 7465023).

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@91171 91177308-0d34-0410-b5e6-96231b3b80d8

include/clang/AST/Expr.h
lib/AST/Expr.cpp
lib/CodeGen/CGExprScalar.cpp
lib/Sema/SemaCXXCast.cpp
test/SemaObjCXX/blocks.mm

index 48bd1e80411885b6a3dcc4c8c6891230d7f5a47e..610cbd8c308d64af5381b85ab7f78a41c63ad8da 100644 (file)
@@ -1575,7 +1575,10 @@ public:
 
     /// CK_AnyPointerToObjCPointerCast - Casting any pointer to objective-c 
     /// pointer
-    CK_AnyPointerToObjCPointerCast
+    CK_AnyPointerToObjCPointerCast,
+    /// CK_AnyPointerToBlockPointerCast - Casting any pointer to block 
+    /// pointer
+    CK_AnyPointerToBlockPointerCast
 
   };
 
index e8758d814deceb719394004b382cbf4e835e0ea9..6eca6a1fa2432aca40c763229320d6a9b510022b 100644 (file)
@@ -560,6 +560,8 @@ const char *CastExpr::getCastKindName() const {
     return "MemberPointerToBoolean";
   case CastExpr::CK_AnyPointerToObjCPointerCast:
     return "AnyPointerToObjCPointerCast";
+  case CastExpr::CK_AnyPointerToBlockPointerCast:
+    return "AnyPointerToBlockPointerCast";
   }
 
   assert(0 && "Unhandled cast kind!");
index 6f65638236583c01e511b7a761f03a6ec2692abc..afb7a798ef7bcd7416c08ae8e0da772e21804528 100644 (file)
@@ -809,6 +809,7 @@ Value *ScalarExprEmitter::EmitCastExpr(CastExpr *CE) {
     break;
 
   case CastExpr::CK_AnyPointerToObjCPointerCast:
+  case CastExpr::CK_AnyPointerToBlockPointerCast:
   case CastExpr::CK_BitCast: {
     Value *Src = Visit(const_cast<Expr*>(E));
     return Builder.CreateBitCast(Src, ConvertType(DestTy));
index 857241d71486ccd647dbd1245ac7ea5a8cb2a5dd..814af9080d846746bc885ea51697637446ad4917 100644 (file)
@@ -545,6 +545,11 @@ static TryCastResult TryStaticCast(Sema &Self, Expr *&SrcExpr,
         Kind = CastExpr::CK_AnyPointerToObjCPointerCast;
         return TC_Success;
       }
+      else if (CStyle && DestType->isBlockPointerType()) {
+        // allow c-style cast of void * to block pointers.
+        Kind = CastExpr::CK_AnyPointerToBlockPointerCast;
+        return TC_Success;
+      }
     }
   }
 
index e3304a41b7308c448e6b55c20bc5e0785b00e3bc..04eb5217e53cf8b2b6d83be785a6c62d3dc40935 100644 (file)
@@ -44,3 +44,9 @@ namespace N {
     foo(N::X()); // okay
 }
 @end
+
+typedef signed char BOOL;
+void foo6(void *block) {  
+       void (^vb)(id obj, int idx, BOOL *stop) = (void (^)(id, int, BOOL *))block;
+    BOOL (^bb)(id obj, int idx, BOOL *stop) = (BOOL (^)(id, int, BOOL *))block;
+}