1 // RUN: %clang_cc1 -fsyntax-only -verify %s 2 3 class X{ 4 public: 5 enum E {Enumerator}; // expected-note 2{{declared here}} 6 int f(); 7 static int mem; 8 static float g(); 9 }; 10 11 void test(X* xp, X x) { 12 int i1 = x.f(); 13 int i2 = xp->f(); 14 x.E; // expected-error{{cannot refer to type member 'E' in 'X' with '.'}} 15 xp->E; // expected-error{{cannot refer to type member 'E' in 'X' with '->'}} 16 int i3 = x.Enumerator; 17 int i4 = xp->Enumerator; 18 x.mem = 1; 19 xp->mem = 2; 20 float f1 = x.g(); 21 float f2 = xp->g(); 22 } 23 24 struct A { 25 int f0; 26 }; 27 struct B { 28 A *f0(); 29 }; 30 int f0(B *b) { 31 return b->f0->f0; // expected-error{{did you mean to call it with no arguments}} 32 } 33 34 int i; 35 36 namespace C { 37 int i; 38 } 39 40 void test2(X *xp) { 41 xp->::i = 7; // expected-error{{qualified member access refers to a member in the global namespace}} 42 xp->C::i = 7; // expected-error{{qualified member access refers to a member in namespace 'C'}} 43 } 44 45 46 namespace test3 { 47 struct NamespaceDecl; 48 49 struct NamedDecl { 50 void *getIdentifier() const; 51 }; 52 53 struct NamespaceDecl : NamedDecl { 54 bool isAnonymousNamespace() const { 55 return !getIdentifier(); 56 } 57 }; 58 } 59 60 namespace test4 { 61 class X { 62 protected: 63 template<typename T> void f(T); 64 }; 65 66 class Y : public X { 67 public: 68 using X::f; 69 }; 70 71 void test_f(Y y) { 72 y.f(17); 73 } 74 } 75 76 namespace test5 { 77 struct A { 78 template <class T> void foo(); 79 }; 80 81 void test0(int x) { 82 x.A::foo<int>(); // expected-error {{'int' is not a structure or union}} 83 } 84 85 void test1(A *x) { 86 x.A::foo<int>(); // expected-error {{'test5::A *' is a pointer}} 87 } 88 89 void test2(A &x) { 90 x->A::foo<int>(); // expected-error {{'test5::A' is not a pointer; maybe you meant to use '.'?}} 91 } 92 } 93 94 namespace PR7508 { 95 struct A { 96 struct CleanupScope {}; 97 void PopCleanupBlock(); // expected-note{{'PopCleanupBlock' declared here}} 98 }; 99 100 void foo(A &a) { 101 a.PopCleanupScope(); // expected-error{{no member named 'PopCleanupScope' in 'PR7508::A'; did you mean 'PopCleanupBlock'?}} 102 } 103 } 104 105 namespace rdar8231724 { 106 namespace N { 107 template<typename T> struct X1; 108 int i; 109 } 110 111 struct X { }; 112 struct Y : X { }; 113 114 template<typename T> struct Z { int n; }; 115 116 void f(Y *y) { 117 y->N::X1<int>; // expected-error{{'rdar8231724::N::X1' is not a member of class 'rdar8231724::Y'}} 118 y->Z<int>::n; // expected-error{{'rdar8231724::Z<int>::n' is not a member of class 'rdar8231724::Y'}} 119 y->template Z<int>::n; // expected-error{{'rdar8231724::Z<int>::n' is not a member of class 'rdar8231724::Y'}} \ 120 // expected-warning{{'template' keyword outside of a template}} 121 } 122 } 123 124 namespace PR9025 { 125 struct S { int x; }; 126 S fun(); // expected-note{{possible target for call}} 127 int fun(int i); // expected-note{{possible target for call}} 128 int g() { 129 return fun.x; // expected-error{{reference to overloaded function could not be resolved; did you mean to call it with no arguments?}} 130 } 131 132 S fun2(); // expected-note{{possible target for call}} 133 S fun2(int i); // expected-note{{possible target for call}} 134 int g2() { 135 return fun2.x; // expected-error{{reference to overloaded function could not be resolved; did you mean to call it with no arguments?}} 136 } 137 138 S fun3(int i=0); // expected-note{{possible target for call}} 139 int fun3(int i, int j); // expected-note{{possible target for call}} 140 int g3() { 141 return fun3.x; // expected-error{{reference to overloaded function could not be resolved; did you mean to call it with no arguments?}} 142 } 143 144 template <typename T> S fun4(); // expected-note{{possible target for call}} 145 int g4() { 146 return fun4.x; // expected-error{{reference to overloaded function could not be resolved; did you mean to call it?}} 147 } 148 149 S fun5(int i); // expected-note{{possible target for call}} 150 S fun5(float f); // expected-note{{possible target for call}} 151 int g5() { 152 return fun5.x; // expected-error{{reference to overloaded function could not be resolved; did you mean to call it?}} 153 } 154 } 155 156 namespace FuncInMemberExpr { 157 struct Vec { int size(); }; 158 Vec fun1(); 159 int test1() { return fun1.size(); } // expected-error {{base of member reference is a function; perhaps you meant to call it with no arguments}} 160 Vec *fun2(); 161 int test2() { return fun2->size(); } // expected-error {{base of member reference is a function; perhaps you meant to call it with no arguments}} 162 Vec fun3(int x = 0); 163 int test3() { return fun3.size(); } // expected-error {{base of member reference is a function; perhaps you meant to call it with no arguments}} 164 } 165 166 namespace DotForSemiTypo { 167 void f(int i) { 168 // If the programmer typo'd '.' for ';', make sure we point at the '.' rather 169 // than the "field name" (whatever the first token on the next line happens to 170 // be). 171 int j = i. // expected-error {{member reference base type 'int' is not a structure or union}} 172 j = 0; 173 } 174 } 175 176 namespace PR15045 { 177 class Cl0 { 178 public: 179 int a; 180 }; 181 182 int f() { 183 Cl0 c; 184 return c->a; // expected-error {{member reference type 'PR15045::Cl0' is not a pointer; maybe you meant to use '.'?}} 185 } 186 187 struct bar { 188 void func(); // expected-note {{'func' declared here}} 189 }; 190 191 struct foo { 192 bar operator->(); // expected-note 2 {{'->' applied to return value of the operator->() declared here}} 193 }; 194 195 template <class T> void call_func(T t) { 196 t->func(); // expected-error-re 2 {{member reference type 'PR15045::bar' is not a pointer{{$}}}} \ 197 // expected-note {{did you mean to use '.' instead?}} 198 } 199 200 void test_arrow_on_non_pointer_records() { 201 bar e; 202 foo f; 203 204 // Show that recovery has happened by also triggering typo correction 205 e->Func(); // expected-error {{member reference type 'PR15045::bar' is not a pointer; maybe you meant to use '.'?}} \ 206 // expected-error {{no member named 'Func' in 'PR15045::bar'; did you mean 'func'?}} 207 208 // Make sure a fixit isn't given in the case that the '->' isn't actually 209 // the problem (the problem is with the return value of an operator->). 210 f->func(); // expected-error-re {{member reference type 'PR15045::bar' is not a pointer{{$}}}} 211 212 call_func(e); // expected-note {{in instantiation of function template specialization 'PR15045::call_func<PR15045::bar>' requested here}} 213 214 call_func(f); // expected-note {{in instantiation of function template specialization 'PR15045::call_func<PR15045::foo>' requested here}} 215 } 216 } 217 218 namespace pr16676 { 219 struct S { int i; }; 220 struct T { S* get_s(); }; 221 int f(S* s) { 222 T t; 223 return t.get_s // expected-error {{reference to non-static member function must be called; did you mean to call it with no arguments?}} 224 .i; // expected-error {{member reference type 'pr16676::S *' is a pointer; maybe you meant to use '->'}} 225 } 226 } 227