1 | // RUN: %clang_cc1 -triple i686-pc-linux-gnu -fsyntax-only -verify %s -Wabsolute-value |
2 | // RUN: %clang_cc1 -triple i686-pc-linux-gnu -fsyntax-only %s -Wabsolute-value -fdiagnostics-parseable-fixits 2>&1 | FileCheck %s |
3 | |
4 | int abs(int); |
5 | |
6 | // Wrong signature |
7 | int fabsf(int); |
8 | // expected-warning@-1{{incompatible redeclaration of library function 'fabsf'}} |
9 | // expected-note@-2{{'fabsf' is a builtin with type 'float (float)'}} |
10 | |
11 | void test_int(int i, unsigned u, long long ll, float f, double d) { |
12 | (void)abs(i); |
13 | |
14 | // Remove abs call |
15 | (void)abs(u); |
16 | // expected-warning@-1{{taking the absolute value of unsigned type 'unsigned int' has no effect}} |
17 | // expected-note@-2{{remove the call to 'abs' since unsigned values cannot be negative}} |
18 | // CHECK: fix-it:"{{.*}}":{[[@LINE-3]]:9-[[@LINE-3]]:12}:"" |
19 | |
20 | int llabs; |
21 | (void)llabs; |
22 | // Conflict in names, no notes |
23 | (void)abs(ll); |
24 | // expected-warning@-1{{absolute value function 'abs' given an argument of type 'long long' but has parameter of type 'int' which may cause truncation of value}} |
25 | |
26 | // Conflict in names, no notes |
27 | (void)abs(f); |
28 | // expected-warning@-1{{using integer absolute value function 'abs' when argument is of floating point type}} |
29 | |
30 | // Suggest header. |
31 | (void)abs(d); |
32 | // expected-warning@-1{{using integer absolute value function 'abs' when argument is of floating point type}} |
33 | // expected-note@-2{{use function 'fabs' instead}} |
34 | // expected-note@-3{{include the header <math.h> or explicitly provide a declaration for 'fabs'}} |
35 | // CHECK: fix-it:"{{.*}}":{[[@LINE-4]]:9-[[@LINE-4]]:12}:"fabs" |
36 | } |
37 | |