231 lines
		
	
	
		
			6.8 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			231 lines
		
	
	
		
			6.8 KiB
		
	
	
	
		
			C++
		
	
	
	
| // RUN: %clang_cc1 -fsyntax-only -verify %s
 | |
| // RUN: %clang_cc1 -fsyntax-only -verify -std=c++98 %s
 | |
| // RUN: %clang_cc1 -fsyntax-only -verify -std=c++11 %s
 | |
| 
 | |
| class X{
 | |
| public:
 | |
|   enum E {Enumerator}; // expected-note 2{{declared here}}
 | |
|   int f();
 | |
|   static int mem;
 | |
|   static float g();
 | |
| };
 | |
| 
 | |
| void test(X* xp, X x) {
 | |
|   int i1 = x.f();
 | |
|   int i2 = xp->f();
 | |
|   x.E; // expected-error{{cannot refer to type member 'E' in 'X' with '.'}}
 | |
|   xp->E; // expected-error{{cannot refer to type member 'E' in 'X' with '->'}}
 | |
|   int i3 = x.Enumerator;
 | |
|   int i4 = xp->Enumerator;
 | |
|   x.mem = 1;
 | |
|   xp->mem = 2;
 | |
|   float f1 = x.g();
 | |
|   float f2 = xp->g();
 | |
| }
 | |
| 
 | |
| struct A {
 | |
|  int f0;
 | |
| };
 | |
| struct B {
 | |
|  A *f0();
 | |
| };
 | |
| int f0(B *b) {
 | |
|   return b->f0->f0; // expected-error{{did you mean to call it with no arguments}}
 | |
| }
 | |
| 
 | |
| int i;
 | |
| 
 | |
| namespace C {
 | |
|   int i;
 | |
| }
 | |
| 
 | |
| void test2(X *xp) {
 | |
|   xp->::i = 7; // expected-error{{qualified member access refers to a member in the global namespace}}
 | |
|   xp->C::i = 7; // expected-error{{qualified member access refers to a member in namespace 'C'}}
 | |
| }
 | |
| 
 | |
| 
 | |
| namespace test3 {
 | |
|   struct NamespaceDecl;
 | |
| 
 | |
|   struct NamedDecl {
 | |
|     void *getIdentifier() const;
 | |
|   };
 | |
| 
 | |
|   struct NamespaceDecl : NamedDecl {
 | |
|     bool isAnonymousNamespace() const {
 | |
|       return !getIdentifier();
 | |
|     }
 | |
|   };
 | |
| }
 | |
| 
 | |
| namespace test4 {
 | |
|   class X {
 | |
|   protected:
 | |
|     template<typename T> void f(T);
 | |
|   };
 | |
| 
 | |
|   class Y : public X {
 | |
|   public:
 | |
|     using X::f;
 | |
|   };
 | |
| 
 | |
|   void test_f(Y y) {
 | |
|     y.f(17);
 | |
|   }
 | |
| }
 | |
| 
 | |
| namespace test5 {
 | |
|   struct A {
 | |
|     template <class T> void foo();
 | |
|   };
 | |
| 
 | |
|   void test0(int x) {
 | |
|     x.A::foo<int>(); // expected-error {{'int' is not a structure or union}}
 | |
|   }
 | |
| 
 | |
|   void test1(A *x) {
 | |
|     x.A::foo<int>(); // expected-error {{'test5::A *' is a pointer}}
 | |
|   }
 | |
| 
 | |
|   void test2(A &x) {
 | |
|     x->A::foo<int>(); // expected-error {{'test5::A' is not a pointer; did you mean to use '.'?}}
 | |
|   }
 | |
| }
 | |
| 
 | |
| namespace PR7508 {
 | |
|   struct A {
 | |
|     struct CleanupScope {};
 | |
|     void PopCleanupBlock(); // expected-note{{'PopCleanupBlock' declared here}}
 | |
|   };
 | |
| 
 | |
|   void foo(A &a) {
 | |
|     a.PopCleanupScope(); // expected-error{{no member named 'PopCleanupScope' in 'PR7508::A'; did you mean 'PopCleanupBlock'?}}
 | |
|   }
 | |
| }
 | |
| 
 | |
| namespace rdar8231724 {
 | |
|   namespace N {
 | |
|     template<typename T> struct X1;
 | |
|     int i;
 | |
|   }
 | |
| 
 | |
|   struct X { };
 | |
|   struct Y : X { };
 | |
| 
 | |
|   template<typename T> struct Z { int n; };
 | |
| 
 | |
|   void f(Y *y) {
 | |
|     y->N::X1<int>; // expected-error{{'rdar8231724::N::X1' is not a member of class 'rdar8231724::Y'}}
 | |
|     y->Z<int>::n; // expected-error{{'rdar8231724::Z<int>::n' is not a member of class 'rdar8231724::Y'}}
 | |
|     y->template Z<int>::n; // expected-error{{'rdar8231724::Z<int>::n' is not a member of class 'rdar8231724::Y'}}
 | |
| #if __cplusplus <= 199711L // C++03 or earlier modes
 | |
|     // expected-warning@-2{{'template' keyword outside of a template}}
 | |
| #endif
 | |
|   }
 | |
| }
 | |
| 
 | |
| namespace PR9025 {
 | |
|   struct S { int x; };
 | |
|   S fun(); // expected-note{{possible target for call}}
 | |
|   int fun(int i); // expected-note{{possible target for call}}
 | |
|   int g() {
 | |
|     return fun.x; // expected-error{{reference to overloaded function could not be resolved; did you mean to call it with no arguments?}}
 | |
|   }
 | |
| 
 | |
|   S fun2(); // expected-note{{possible target for call}}
 | |
|   S fun2(int i); // expected-note{{possible target for call}}
 | |
|   int g2() {
 | |
|     return fun2.x; // expected-error{{reference to overloaded function could not be resolved; did you mean to call it with no arguments?}}
 | |
|   }
 | |
| 
 | |
|   S fun3(int i=0); // expected-note{{possible target for call}}
 | |
|   int fun3(int i, int j); // expected-note{{possible target for call}}
 | |
|   int g3() {
 | |
|     return fun3.x; // expected-error{{reference to overloaded function could not be resolved; did you mean to call it with no arguments?}}
 | |
|   }
 | |
| 
 | |
|   template <typename T> S fun4(); // expected-note{{possible target for call}}
 | |
|   int g4() {
 | |
|     return fun4.x; // expected-error{{reference to overloaded function could not be resolved; did you mean to call it?}}
 | |
|   }
 | |
| 
 | |
|   S fun5(int i); // expected-note{{possible target for call}}
 | |
|   S fun5(float f); // expected-note{{possible target for call}}
 | |
|   int g5() {
 | |
|     return fun5.x; // expected-error{{reference to overloaded function could not be resolved; did you mean to call it?}}
 | |
|   }
 | |
| }
 | |
| 
 | |
| namespace FuncInMemberExpr {
 | |
|   struct Vec { int size(); };
 | |
|   Vec fun1();
 | |
|   int test1() { return fun1.size(); } // expected-error {{base of member reference is a function; perhaps you meant to call it with no arguments}}
 | |
|   Vec *fun2();
 | |
|   int test2() { return fun2->size(); } // expected-error {{base of member reference is a function; perhaps you meant to call it with no arguments}}
 | |
|   Vec fun3(int x = 0);
 | |
|   int test3() { return fun3.size(); } // expected-error {{base of member reference is a function; perhaps you meant to call it with no arguments}}
 | |
| }
 | |
| 
 | |
| namespace DotForSemiTypo {
 | |
| void f(int i) {
 | |
|   // If the programmer typo'd '.' for ';', make sure we point at the '.' rather
 | |
|   // than the "field name" (whatever the first token on the next line happens to
 | |
|   // be).
 | |
|   int j = i. // expected-error {{member reference base type 'int' is not a structure or union}}
 | |
|   j = 0;
 | |
| }
 | |
| }
 | |
| 
 | |
| namespace PR15045 {
 | |
|   class Cl0 {
 | |
|   public:
 | |
|     int a;
 | |
|   };
 | |
| 
 | |
|   int f() {
 | |
|     Cl0 c;
 | |
|     return c->a;  // expected-error {{member reference type 'PR15045::Cl0' is not a pointer; did you mean to use '.'?}}
 | |
|   }
 | |
| 
 | |
|   struct bar {
 | |
|     void func();  // expected-note {{'func' declared here}}
 | |
|   };
 | |
| 
 | |
|   struct foo {
 | |
|     bar operator->();  // expected-note 2 {{'->' applied to return value of the operator->() declared here}}
 | |
|   };
 | |
| 
 | |
|   template <class T> void call_func(T t) {
 | |
|     t->func();  // expected-error-re 2 {{member reference type 'PR15045::bar' is not a pointer{{$}}}} \
 | |
|                 // expected-note {{did you mean to use '.' instead?}}
 | |
|   }
 | |
| 
 | |
|   void test_arrow_on_non_pointer_records() {
 | |
|     bar e;
 | |
|     foo f;
 | |
| 
 | |
|     // Show that recovery has happened by also triggering typo correction
 | |
|     e->Func();  // expected-error {{member reference type 'PR15045::bar' is not a pointer; did you mean to use '.'?}} \
 | |
|                 // expected-error {{no member named 'Func' in 'PR15045::bar'; did you mean 'func'?}}
 | |
| 
 | |
|     // Make sure a fixit isn't given in the case that the '->' isn't actually
 | |
|     // the problem (the problem is with the return value of an operator->).
 | |
|     f->func();  // expected-error-re {{member reference type 'PR15045::bar' is not a pointer{{$}}}}
 | |
| 
 | |
|     call_func(e);  // expected-note {{in instantiation of function template specialization 'PR15045::call_func<PR15045::bar>' requested here}}
 | |
| 
 | |
|     call_func(f);  // expected-note {{in instantiation of function template specialization 'PR15045::call_func<PR15045::foo>' requested here}}
 | |
|   }
 | |
| }
 | |
| 
 | |
| namespace pr16676 {
 | |
|   struct S { int i; };
 | |
|   struct T { S* get_s(); };
 | |
|   int f(S* s) {
 | |
|     T t;
 | |
|     return t.get_s  // expected-error {{reference to non-static member function must be called; did you mean to call it with no arguments?}}
 | |
|         .i;  // expected-error {{member reference type 'pr16676::S *' is a pointer; did you mean to use '->'}}
 | |
|   }
 | |
| }
 |