foo()1*67e74705SXin Livoid foo() { 2*67e74705SXin Li int voodoo; 3*67e74705SXin Li voodoo = voodoo + 1; 4*67e74705SXin Li } 5*67e74705SXin Li bar()6*67e74705SXin Livoid 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 Livoid 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 Livoid 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 Livoid 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