]> granicus.if.org Git - clang/commitdiff
__typeof should be able to handle block pointer types when
authorFariborz Jahanian <fjahanian@apple.com>
Thu, 18 Feb 2010 01:20:22 +0000 (01:20 +0000)
committerFariborz Jahanian <fjahanian@apple.com>
Thu, 18 Feb 2010 01:20:22 +0000 (01:20 +0000)
rewriting. Fixes radar 7659483.

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

lib/Frontend/RewriteObjC.cpp
test/Rewriter/rewrite-block-pointer.mm

index 9d4d6047160479d99ae57f7fd9d932ea6cfc0cab..5d99491cd6a1962a85cf178945bd6efe156862ae 100644 (file)
@@ -4416,7 +4416,7 @@ void RewriteObjC::RewriteCastExpr(CStyleCastExpr *CE) {
     const TypeOfExprType *TypeOfExprTypePtr = cast<TypeOfExprType>(TypePtr);
     QT = TypeOfExprTypePtr->getUnderlyingExpr()->getType();
     std::string TypeAsString = "(";
-    TypeAsString += QT.getAsString();
+    RewriteBlockPointerType(TypeAsString, QT);
     TypeAsString += ")";
     ReplaceText(LocStart, endBuf-startBuf+1, TypeAsString);
     return;
index 229eb8950080e7bba536e42f83021415052e75c5..4a4fa347084775ac2c646adf2d85c761bc5e6c47 100644 (file)
@@ -27,3 +27,9 @@ static void y(int (^cmp)(int, int)) {
                x(cmp);
     });
 }
+
+// radar 7659483
+void *_Block_copy(const void *aBlock);
+void x(void (^block)(void)) {
+        block = ((__typeof(block))_Block_copy((const void *)(block)));
+}