|  | // 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'}} | 
|  | } | 
|  |  |