summaryrefslogtreecommitdiffstats
path: root/test/FixIt/format-no-fixit.m
blob: 36ecd3f26c0122774de7175de4152a9288556dc9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
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'}}
}