]> granicus.if.org Git - clang/commitdiff
Fix objc rewriting bug casting to qualified objective-c pointetr.
authorFariborz Jahanian <fjahanian@apple.com>
Sat, 26 Feb 2011 01:31:36 +0000 (01:31 +0000)
committerFariborz Jahanian <fjahanian@apple.com>
Sat, 26 Feb 2011 01:31:36 +0000 (01:31 +0000)
// rdar://9056351

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

lib/Rewrite/RewriteObjC.cpp
test/Rewriter/rewrite-vararg.m [new file with mode: 0644]

index 9def4da8b7cb36ffb6c367587326e4a5c78efd8c..0263f657a6e3a900b64b252046ee7e75cf8d5d63 100644 (file)
@@ -2988,9 +2988,9 @@ Stmt *RewriteObjC::SynthMessageExpr(ObjCMessageExpr *Exp,
     // Make all implicit casts explicit...ICE comes in handy:-)
     if (ImplicitCastExpr *ICE = dyn_cast<ImplicitCastExpr>(userExpr)) {
       // Reuse the ICE type, it is exactly what the doctor ordered.
-      QualType type = ICE->getType()->isObjCQualifiedIdType()
-                                ? Context->getObjCIdType()
-                                : ICE->getType();
+      QualType type = ICE->getType();
+      if (needToScanForQualifiers(type))
+        type = Context->getObjCIdType();
       // Make sure we convert "type (^)(...)" to "type (*)(...)".
       (void)convertBlockPointerToFunctionPointer(type);
       userExpr = NoTypeInfoCStyleCastExpr(Context, type, CK_BitCast,
diff --git a/test/Rewriter/rewrite-vararg.m b/test/Rewriter/rewrite-vararg.m
new file mode 100644 (file)
index 0000000..d454031
--- /dev/null
@@ -0,0 +1,27 @@
+// RUN: %clang_cc1 -x objective-c++ -Wno-return-type -fblocks -fms-extensions -rewrite-objc %s -o %t-rw.cpp
+// RUN: %clang_cc1 -fsyntax-only -fblocks -Wno-address-of-temporary -D"id=void*" -D"SEL=void*" -D"__declspec(X)=" %t-rw.cpp
+
+// rdar://9056351
+void *sel_registerName(const char *);
+
+@interface NSObject @end
+@class NSString;
+
+@protocol P
+  -(void)ParliamentFunkadelic;
+@end
+       
+@interface Foo {
+  NSObject <P> *_dataSource;
+}
+@end
+       
+@interface Bar { }
++(void)WhateverBar:(NSString*)format, ...;
+@end
+       
+@implementation Foo
+-(void)WhateverFoo {
+       [Bar WhateverBar:@"ISyncSessionDriverDataSource %@ responded poorly", _dataSource];
+}
+@end