summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFariborz Jahanian <fjahanian@apple.com>2010-02-18 01:20:22 +0000
committerFariborz Jahanian <fjahanian@apple.com>2010-02-18 01:20:22 +0000
commitf50679151b1b974dbe2ea7805692ae78eee89214 (patch)
tree8e2b9e96986e02ce9fe1e16ca567c19053b7b3c1
parente5ad57a3ed0dea8c59015216d28bf924f06ec387 (diff)
downloadbcm5719-llvm-f50679151b1b974dbe2ea7805692ae78eee89214.tar.gz
bcm5719-llvm-f50679151b1b974dbe2ea7805692ae78eee89214.zip
__typeof should be able to handle block pointer types when
rewriting. Fixes radar 7659483. llvm-svn: 96549
-rw-r--r--clang/lib/Frontend/RewriteObjC.cpp2
-rw-r--r--clang/test/Rewriter/rewrite-block-pointer.mm6
2 files changed, 7 insertions, 1 deletions
diff --git a/clang/lib/Frontend/RewriteObjC.cpp b/clang/lib/Frontend/RewriteObjC.cpp
index 9d4d6047160..5d99491cd6a 100644
--- a/clang/lib/Frontend/RewriteObjC.cpp
+++ b/clang/lib/Frontend/RewriteObjC.cpp
@@ -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;
diff --git a/clang/test/Rewriter/rewrite-block-pointer.mm b/clang/test/Rewriter/rewrite-block-pointer.mm
index 229eb895008..4a4fa347084 100644
--- a/clang/test/Rewriter/rewrite-block-pointer.mm
+++ b/clang/test/Rewriter/rewrite-block-pointer.mm
@@ -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)));
+}
OpenPOWER on IntegriCloud