aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/Frontend/RewriteObjC.cpp20
-rw-r--r--test/Rewriter/rewrite-cast-ivar-access.mm6
2 files changed, 17 insertions, 9 deletions
diff --git a/lib/Frontend/RewriteObjC.cpp b/lib/Frontend/RewriteObjC.cpp
index 19c714da3d..e473adbf9e 100644
--- a/lib/Frontend/RewriteObjC.cpp
+++ b/lib/Frontend/RewriteObjC.cpp
@@ -4308,15 +4308,17 @@ void RewriteObjC::RewriteCastExpr(CStyleCastExpr *CE) {
TypeAsString.c_str(), TypeAsString.size());
return;
}
- if (QT->isObjCObjectPointerType()) {
- QualType ptee = QT->getAs<ObjCObjectPointerType>()->getPointeeType();
- std::string TypeAsString = "(struct ";
- TypeAsString += ptee.getAsString();
- TypeAsString += "_IMPL *";
- TypeAsString += ")";
- ReplaceText(LocStart, endBuf-startBuf+1,
- TypeAsString.c_str(), TypeAsString.size());
- return;
+ if (LangOpts.Microsoft && QT->isObjCObjectPointerType()) {
+ if (isa<ObjCInterfaceType>(QT->getPointeeType())) {
+ QualType ptee = QT->getAs<ObjCObjectPointerType>()->getPointeeType();
+ std::string TypeAsString = "(struct ";
+ TypeAsString += ptee.getAsString();
+ TypeAsString += "_IMPL *";
+ TypeAsString += ")";
+ ReplaceText(LocStart, endBuf-startBuf+1,
+ TypeAsString.c_str(), TypeAsString.size());
+ return;
+ }
}
// advance the location to startArgList.
const char *argPtr = startBuf;
diff --git a/test/Rewriter/rewrite-cast-ivar-access.mm b/test/Rewriter/rewrite-cast-ivar-access.mm
index bdda689512..177824d026 100644
--- a/test/Rewriter/rewrite-cast-ivar-access.mm
+++ b/test/Rewriter/rewrite-cast-ivar-access.mm
@@ -20,5 +20,11 @@
}
@end
+void objc_assign_strongCast(id);
+void __CFAssignWithWriteBarrier(void **location, void *value) {
+ objc_assign_strongCast((id)value);
+}
+
// CHECK-LP: ((struct G_IMPL *)arg)->ivar
+// CHECK-LP: objc_assign_strongCast((id)value)