xref: /aosp_15_r20/external/clang/test/Misc/serialized-diags.c (revision 67e74705e28f6214e480b399dd47ea732279e315)

foo()1*67e74705SXin Li void foo() {
2*67e74705SXin Li   int voodoo;
3*67e74705SXin Li   voodoo = voodoo + 1;
4*67e74705SXin Li }
5*67e74705SXin Li 
bar()6*67e74705SXin Li void bar() {
7*67e74705SXin Li   int dragon;
8*67e74705SXin Li   dragon = dragon + 1
9*67e74705SXin Li }
10*67e74705SXin Li 
11*67e74705SXin Li // Test handling of FixIts that only remove text.
12*67e74705SXin Li int baz();
qux(int x)13*67e74705SXin Li void qux(int x) {
14*67e74705SXin Li   if ((x == baz()))
15*67e74705SXin Li    return;
16*67e74705SXin Li }
17*67e74705SXin Li 
18*67e74705SXin Li // Test handling of macros.
19*67e74705SXin Li void taz(int x, int y);
20*67e74705SXin Li #define false 0
testMacro()21*67e74705SXin Li void testMacro() {
22*67e74705SXin Li   taz(0, 0, false);
23*67e74705SXin Li }
24*67e74705SXin Li 
25*67e74705SXin Li // Test handling of issues from #includes.
26*67e74705SXin Li #include "serialized-diags.h"
27*67e74705SXin Li 
28*67e74705SXin Li // Test handling of warnings that have empty fixits.
rdar11040133()29*67e74705SXin Li void rdar11040133() {
30*67e74705SXin Li   unsigned x;
31*67e74705SXin Li }
32*67e74705SXin Li 
33*67e74705SXin Li // RUN: rm -f %t
34*67e74705SXin Li // RUN: not %clang -Wall -fsyntax-only %s --serialize-diagnostics %t.diag > /dev/null 2>&1
35*67e74705SXin Li // RUN: c-index-test -read-diagnostics %t.diag > %t 2>&1
36*67e74705SXin Li // RUN: FileCheck --input-file=%t %s
37*67e74705SXin Li 
38*67e74705SXin Li // This test case tests that we can handle multiple diagnostics which contain
39*67e74705SXin Li // FIXITs at different levels (one at the note, another at the main diagnostic).
40*67e74705SXin Li 
41*67e74705SXin Li // CHECK: {{.*[/\\]}}serialized-diags.c:3:12: warning: variable 'voodoo' is uninitialized when used here [-Wuninitialized]
42*67e74705SXin Li // CHECK: Range: {{.*[/\\]}}serialized-diags.c:3:12 {{.*[/\\]}}serialized-diags.c:3:18
43*67e74705SXin Li // CHECK: +-{{.*[/\\]}}serialized-diags.c:2:13: note: initialize the variable 'voodoo' to silence this warning []
44*67e74705SXin Li // CHECK: +-FIXIT: ({{.*[/\\]}}serialized-diags.c:2:13 - {{.*[/\\]}}serialized-diags.c:2:13): " = 0"
45*67e74705SXin Li // CHECK: {{.*[/\\]}}serialized-diags.c:8:22: error: expected ';' after expression []
46*67e74705SXin Li // CHECK: FIXIT: ({{.*[/\\]}}serialized-diags.c:8:22 - {{.*[/\\]}}serialized-diags.c:8:22): ";"
47*67e74705SXin Li // CHECK: {{.*[/\\]}}serialized-diags.c:14:10: warning: equality comparison with extraneous parentheses [-Wparentheses-equality]
48*67e74705SXin Li // CHECK: Range: {{.*[/\\]}}serialized-diags.c:14:8 {{.*[/\\]}}serialized-diags.c:14:18
49*67e74705SXin Li // CHECK: +-{{.*[/\\]}}serialized-diags.c:14:10: note: remove extraneous parentheses around the comparison to silence this warning []
50*67e74705SXin Li // CHECK: +-FIXIT: ({{.*[/\\]}}serialized-diags.c:14:7 - {{.*[/\\]}}serialized-diags.c:14:8): ""
51*67e74705SXin Li // CHECK: +-FIXIT: ({{.*[/\\]}}serialized-diags.c:14:18 - {{.*[/\\]}}serialized-diags.c:14:19): ""
52*67e74705SXin Li // CHECK: +-{{.*[/\\]}}serialized-diags.c:14:10: note: use '=' to turn this equality comparison into an assignment []
53*67e74705SXin Li // CHECK: +-FIXIT: ({{.*[/\\]}}serialized-diags.c:14:10 - {{.*[/\\]}}serialized-diags.c:14:12): "="
54*67e74705SXin Li // CHECK: {{.*[/\\]}}serialized-diags.c:22:13: error: too many arguments to function call, expected 2, have 3 []
55*67e74705SXin Li // CHECK: Range: {{.*[/\\]}}serialized-diags.c:22:3 {{.*[/\\]}}serialized-diags.c:22:6
56*67e74705SXin Li // CHECK: Range: {{.*[/\\]}}serialized-diags.c:22:13 {{.*[/\\]}}serialized-diags.c:22:18
57*67e74705SXin Li // CHECK: +-{{.*[/\\]}}serialized-diags.c:20:15: note: expanded from macro 'false' []
58*67e74705SXin Li // CHECK: +-Range: {{.*[/\\]}}serialized-diags.c:20:15 {{.*[/\\]}}serialized-diags.c:20:16
59*67e74705SXin Li // CHECK: +-{{.*[/\\]}}serialized-diags.c:19:1: note: 'taz' declared here []
60*67e74705SXin Li // CHECK: {{.*[/\\]}}serialized-diags.h:5:7: warning: incompatible integer to pointer conversion initializing 'char *' with an expression of type 'int' [-Wint-conversion]
61*67e74705SXin Li // CHECK: Range: {{.*[/\\]}}serialized-diags.h:5:16 {{.*[/\\]}}serialized-diags.h:5:17
62*67e74705SXin Li // CHECK: +-{{.*[/\\]}}serialized-diags.c:26:10: note: in file included from {{.*[/\\]}}serialized-diags.c:26: []
63*67e74705SXin Li // CHECK: Number FIXITs = 0
64*67e74705SXin Li // CHECK: {{.*[/\\]}}serialized-diags.c:30:12: warning: unused variable 'x'
65*67e74705SXin Li // CHECK: Number FIXITs = 0
66*67e74705SXin Li // CHECK: Number of diagnostics: 6
67