1 // RUN: not %clang_cc1 -fdiagnostics-parseable-fixits -x c++ %s 2> %t
2 // RUN: FileCheck %s < %t
3 // PR5941
4 // END.
5 
6 /* Test fixits for * and & mismatch in function arguments.
7  * Since fixits are on the notes, they cannot be applied automatically. */
8 
9 typedef int intTy;
10 typedef int intTy2;
11 
12 void f0(int *a);
13 void f1(double *a);
14 void f1(intTy &a);
15 
f2(intTy2 * a)16 void f2(intTy2 *a) {
17 // CHECK: error: no matching function for call to 'f1
18 // CHECK: dereference the argument with *
19 // CHECK: void f1(intTy &a);
20 // CHECK: fix-it{{.*}}*(
21 // CHECK-NEXT: fix-it{{.*}})
22 // CHECK: void f1(double *a);
23   f1(a + 1);
24 
25 // This call cannot be fixed since without resulting in null pointer dereference.
26 // CHECK: error: no matching function for call to 'f1
27 // CHECK-NOT: dereference the argument with *
28 // CHECK-NOT: fix-it
29   f1((int *)0);
30 }
31 
f3(int & a)32 void f3(int &a) {
33 // CHECK: error: no matching function for call to 'f0
34 // CHECK: fix-it{{.*}}&
35  f0(a);
36 }
37 
38 
39 void m(int *a, const int *b); // match 2
40 void m(double *a, int *b); // no match
41 void m(int *a, double *b); // no match
42 void m(intTy &a, int *b); // match 1
43 
mcaller(intTy2 a,int b)44 void mcaller(intTy2 a, int b) {
45 // CHECK: error: no matching function for call to 'm
46 // CHECK: take the address of the argument with &
47 // CHECK: fix-it{{.*}}&
48 // CHECK: take the address of the argument with &
49 // CHECK: fix-it{{.*}}&
50 // CHECK: fix-it{{.*}}&
51   m(a, b);
52 
53 // This call cannot be fixed because (a + 1) is not an l-value.
54 // CHECK: error: no matching function for call to 'm
55 // CHECK-NOT: fix-it
56   m(a + 1, b);
57 }
58 
59 // Test derived to base conversions.
60 struct A {
61   int xx;
62 };
63 
64 struct B : public A {
65   double y;
66 };
67 
68 class C : A {};
69 
70 bool br(A &a);
71 bool bp(A *a);
72 bool dv(B b);
73 
74 void u(int x);
75 void u(const C *x);
76 void u(double x);
77 
dbcaller(A * ptra,B * ptrb,C & c,B & refb)78 void dbcaller(A *ptra, B *ptrb, C &c, B &refb) {
79   B b;
80 
81 // CHECK: error: no matching function for call to 'br
82 // CHECK: fix-it{{.*}}*
83   br(ptrb); // good
84 
85 // CHECK: error: no matching function for call to 'bp
86 // CHECK: fix-it{{.*}}&
87   bp(b); // good
88 
89 // CHECK: error: no matching function for call to 'dv
90 // CHECK-NOT: fix-it
91   dv(ptra); // bad: base to derived
92 
93 // CHECK: error: no matching function for call to 'dv
94 // CHECK: remove &
95   dv(&b);
96 
97 // CHECK: error: no matching function for call to 'bp
98 // CHECK: remove *
99   bp(*ptra);
100 
101 // CHECK: error: no viable overloaded '='
102 // CHECK: remove &
103   b = &refb;
104 
105 // TODO: Test that we do not provide a fixit when inheritance is private.
106 // CHECK: error: no matching function for call to 'bp
107 // There should not be a fixit here:
108 // CHECK: fix-it
109   bp(c);
110 
111 // CHECK: no matching function for call to 'u'
112 // CHECK: candidate function not viable: no known conversion from 'C' to 'const C *' for 1st argument; take the address of the argument with &
113 // CHECK: candidate function not viable
114 // CHECK: candidate function not viable
115   u(c);
116 }
117 
118 // CHECK: errors generated
119