File: format-no-fixit.m

package info (click to toggle)
llvm-toolchain-6.0 1%3A6.0.1-10
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 598,080 kB
  • sloc: cpp: 3,046,253; ansic: 595,057; asm: 271,965; python: 128,926; objc: 106,554; sh: 21,906; lisp: 10,191; pascal: 6,094; ml: 5,544; perl: 5,265; makefile: 2,227; cs: 2,027; xml: 686; php: 212; csh: 117
file content (30 lines) | stat: -rw-r--r-- 1,254 bytes parent folder | download | duplicates (37)
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'}}
}