227 lines
6.6 KiB
C++
227 lines
6.6 KiB
C++
|
// RUN: %clang_cc1 -fsyntax-only -verify %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; maybe you meant 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'}} \
|
||
|
// expected-warning{{'template' keyword outside of a template}}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
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; maybe you meant 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; maybe you meant 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; maybe you meant to use '->'}}
|
||
|
}
|
||
|
}
|