summaryrefslogtreecommitdiff
path: root/test/FixIt/format-no-fixit.m
diff options
context:
space:
mode:
Diffstat (limited to 'test/FixIt/format-no-fixit.m')
-rw-r--r--test/FixIt/format-no-fixit.m30
1 files changed, 30 insertions, 0 deletions
diff --git a/test/FixIt/format-no-fixit.m b/test/FixIt/format-no-fixit.m
new file mode 100644
index 0000000000000..36ecd3f26c012
--- /dev/null
+++ b/test/FixIt/format-no-fixit.m
@@ -0,0 +1,30 @@
+// RUN: %clang_cc1 -fsyntax-only -verify %s
+// RUN: %clang_cc1 -fdiagnostics-parseable-fixits -fsyntax-only %s 2>&1 | FileCheck %s
+
+// CHECK-NOT: fix-it:
+
+@class NSString;
+extern void NSLog(NSString *format, ...);
+int printf(const char * restrict, ...) ;
+
+
+void test_object_correction (id x) {
+ printf("%d", x); // expected-warning{{format specifies type 'int' but the argument has type 'id'}}
+ printf("%s", x); // expected-warning{{format specifies type 'char *' but the argument has type 'id'}}
+ printf("%lf", x); // expected-warning{{format specifies type 'double' but the argument has type 'id'}}
+}
+
+
+// Old-style Core Foundation types do not have __attribute__((NSObject)).
+// This is okay, but we won't suggest a fixit; arbitrary structure pointers may
+// not be objects.
+typedef const struct __CFString * CFStringRef;
+
+void test_cf_object_correction (CFStringRef x) {
+ NSLog(@"%@", x); // no-warning
+
+ NSLog(@"%d", x); // expected-warning{{format specifies type 'int' but the argument has type 'CFStringRef'}}
+ NSLog(@"%s", x); // expected-warning{{format specifies type 'char *' but the argument has type 'CFStringRef'}}
+ NSLog(@"%lf", x); // expected-warning{{format specifies type 'double' but the argument has type 'CFStringRef'}}
+}
+