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