| // 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 '->'}} |
| } |
| } |