blob: d8be6bca49157db5051774904b22b096b1706024 [file] [log] [blame]
Douglas Gregoreaebc752008-11-06 23:29:22 +00001// RUN: clang -fsyntax-only -verify %s
2class X { };
3
4X operator+(X, X);
5
6void f(X x) {
7 x = x + x;
8}
9
10struct Y;
11struct Z;
12
13struct Y {
14 Y(const Z&);
15};
16
17struct Z {
18 Z(const Y&);
19};
20
21Y operator+(Y, Y);
22bool operator-(Y, Y); // expected-note{{candidate function}}
23bool operator-(Z, Z); // expected-note{{candidate function}}
24
25void g(Y y, Z z) {
26 y = y + z;
27 bool b = y - z; // expected-error{{use of overloaded operator '-' is ambiguous; candidates are:}}
28}
29
Douglas Gregor96176b32008-11-18 23:14:02 +000030struct A {
31 bool operator==(Z&); // expected-note{{candidate function}}
32};
Douglas Gregoreaebc752008-11-06 23:29:22 +000033
Douglas Gregor96176b32008-11-18 23:14:02 +000034A make_A();
35
36bool operator==(A&, Z&); // expected-note{{candidate function}}
37
38void h(A a, const A ac, Z z) {
39 make_A() == z;
40 a == z; // expected-error{{use of overloaded operator '==' is ambiguous; candidates are:}}
41 ac == z; // expected-error{{invalid operands to binary expression ('struct A const' and 'struct Z')}}
42}
43
44struct B {
45 bool operator==(const B&) const;
46
47 void test(Z z) {
48 make_A() == z;
49 }
50};
Douglas Gregor447b69e2008-11-19 03:25:36 +000051
52enum Enum1 { };
53enum Enum2 { };
54
55struct E1 {
56 E1(Enum1) { }
57};
58
59struct E2 {
60 E2(Enum2);
61};
62
63// C++ [over.match.oper]p3 - enum restriction.
64float& operator==(E1, E2);
65
66void enum_test(Enum1 enum1, Enum2 enum2, E1 e1, E2 e2) {
67 float &f1 = (e1 == e2);
68 float &f2 = (enum1 == e2);
69 float &f3 = (e1 == enum2);
70 float &f4 = (enum1 == enum2); // expected-error{{non-const reference to type 'float' cannot be initialized with a temporary of type '_Bool'}}
71}
Douglas Gregor74253732008-11-19 15:42:04 +000072
73
74struct PostInc {
75 PostInc operator++(int);
76 PostInc& operator++();
77};
78
79struct PostDec {
80 PostDec operator--(int);
81 PostDec& operator--();
82};
83
84void incdec_test(PostInc pi, PostDec pd) {
85 const PostInc& pi1 = pi++;
86 const PostDec& pd1 = pd--;
87 PostInc &pi2 = ++pi;
88 PostDec &pd2 = --pd;
89}
90
91struct SmartPtr {
92 int& operator*();
Douglas Gregor1ca50c32008-11-21 15:36:28 +000093 long& operator*() const volatile;
Douglas Gregor74253732008-11-19 15:42:04 +000094};
95
Douglas Gregor1ca50c32008-11-21 15:36:28 +000096void test_smartptr(SmartPtr ptr, const SmartPtr cptr,
97 const volatile SmartPtr cvptr) {
Douglas Gregor74253732008-11-19 15:42:04 +000098 int &ir = *ptr;
Douglas Gregor1ca50c32008-11-21 15:36:28 +000099 long &lr = *cptr;
100 long &lr2 = *cvptr;
Douglas Gregor74253732008-11-19 15:42:04 +0000101}
Douglas Gregor337c6b92008-11-19 17:17:41 +0000102
103
104struct ArrayLike {
105 int& operator[](int);
106};
107
108void test_arraylike(ArrayLike a) {
109 int& ir = a[17];
110}
111
112struct SmartRef {
113 int* operator&();
114};
115
116void test_smartref(SmartRef r) {
117 int* ip = &r;
118}
119
120bool& operator,(X, Y);
121
122void test_comma(X x, Y y) {
123 bool& b1 = (x, y);
124 X& xr = (x, x);
125}
Douglas Gregorf9eb9052008-11-19 21:05:33 +0000126
127
128struct Callable {
129 int& operator()(int, double = 2.71828); // expected-note{{candidate function}}
130 float& operator()(int, double, long, ...); // expected-note{{candidate function}}
131};
132
133void test_callable(Callable c) {
134 int &ir = c(1);
135 float &fr = c(1, 3.14159, 17, 42);
136
137 c(); // expected-error{{no matching function for call to object of type 'struct Callable'; candidates are:}}
138}
Douglas Gregor106c6eb2008-11-19 22:57:39 +0000139
Douglas Gregor621b3932008-11-21 02:54:28 +0000140typedef float FLOAT;
141typedef int& INTREF;
142typedef INTREF Func1(FLOAT, double);
Douglas Gregor106c6eb2008-11-19 22:57:39 +0000143typedef float& Func2(int, double);
144
145struct ConvertToFunc {
Douglas Gregor621b3932008-11-21 02:54:28 +0000146 operator Func1*(); // expected-note{{conversion candidate of type 'INTREF (*)(FLOAT, double)'}}
Douglas Gregor106c6eb2008-11-19 22:57:39 +0000147 operator Func2&(); // expected-note{{conversion candidate of type 'float &(&)(int, double)'}}
Douglas Gregor9ebae312008-11-19 22:59:19 +0000148 void operator()();
Douglas Gregor106c6eb2008-11-19 22:57:39 +0000149};
150
151void test_funcptr_call(ConvertToFunc ctf) {
152 int &i1 = ctf(1.0f, 2.0);
153 float &f2 = ctf((short int)1, 1.0f);
154 ctf((long int)17, 2.0); // expected-error{{error: call to object of type 'struct ConvertToFunc' is ambiguous; candidates are:}}
Douglas Gregor9ebae312008-11-19 22:59:19 +0000155 ctf();
Douglas Gregor106c6eb2008-11-19 22:57:39 +0000156}
Douglas Gregor8ba10742008-11-20 16:27:02 +0000157
158struct HasMember {
159 int m;
160};
161
162struct Arrow1 {
163 HasMember* operator->();
164};
165
166struct Arrow2 {
167 Arrow1 operator->(); // expected-note{{candidate function}}
168};
169
170void test_arrow(Arrow1 a1, Arrow2 a2, const Arrow2 a3) {
171 int &i1 = a1->m;
172 int &i2 = a2->m;
Sebastian Redle4c452c2008-11-22 13:44:36 +0000173 a3->m; // expected-error{{no viable overloaded 'operator->'; candidate is}}
Douglas Gregor8ba10742008-11-20 16:27:02 +0000174}
Douglas Gregore63ef482009-01-13 00:11:19 +0000175
176struct CopyConBase {
177};
178
179struct CopyCon : public CopyConBase {
180 CopyCon(const CopyConBase &Base);
181
182 CopyCon(const CopyConBase *Base) {
183 *this = *Base;
184 }
185};