File: format-no-fixit.m

package info (click to toggle)
llvm-toolchain-7 1%3A7.0.1-8
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 733,456 kB
  • sloc: cpp: 3,776,651; ansic: 633,271; asm: 350,301; python: 142,716; objc: 107,612; sh: 22,626; lisp: 11,056; perl: 7,999; pascal: 6,742; ml: 5,537; awk: 3,536; makefile: 2,557; cs: 2,027; xml: 841; ruby: 156
file content (30 lines) | stat: -rw-r--r-- 1,254 bytes parent folder | download | duplicates (38)
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'}}
}