2009-12-16 04:14:24 +08:00
|
|
|
// RUN: %clang_cc1 -fsyntax-only -verify %s
|
2009-08-06 11:17:00 +08:00
|
|
|
namespace A
|
|
|
|
{
|
|
|
|
namespace B
|
|
|
|
{
|
2009-09-03 06:59:36 +08:00
|
|
|
struct base // expected-note{{object type}}
|
2009-08-06 11:17:00 +08:00
|
|
|
{
|
|
|
|
void x() {}
|
|
|
|
void y() {}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
struct member
|
|
|
|
{
|
|
|
|
void foo();
|
|
|
|
};
|
|
|
|
|
|
|
|
struct middleman
|
|
|
|
{
|
|
|
|
member * operator->() { return 0; }
|
|
|
|
};
|
|
|
|
|
|
|
|
struct sub : B::base
|
|
|
|
{
|
|
|
|
void x() {}
|
|
|
|
middleman operator->() { return middleman(); }
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
struct bad
|
|
|
|
{
|
|
|
|
int x();
|
|
|
|
};
|
|
|
|
|
|
|
|
namespace C
|
|
|
|
{
|
|
|
|
void fun()
|
|
|
|
{
|
|
|
|
A::sub a;
|
|
|
|
|
|
|
|
a.x();
|
|
|
|
|
|
|
|
a.sub::x();
|
|
|
|
a.base::x();
|
|
|
|
|
|
|
|
a.B::base::x(); // expected-error{{use of undeclared identifier 'B'}}
|
|
|
|
|
|
|
|
a.A::sub::x();
|
|
|
|
a.A::B::base::x();
|
|
|
|
|
2009-12-01 06:42:35 +08:00
|
|
|
a.bad::x(); // expected-error{{type 'struct bad' is not a direct or virtual base of ''A::sub''}}
|
2009-08-06 11:17:00 +08:00
|
|
|
|
|
|
|
a->foo();
|
|
|
|
a->member::foo();
|
|
|
|
a->A::member::foo();
|
|
|
|
}
|
|
|
|
|
|
|
|
void fun2()
|
|
|
|
{
|
|
|
|
A::sub *a;
|
|
|
|
|
|
|
|
a->x();
|
|
|
|
|
|
|
|
a->sub::x();
|
|
|
|
a->base::x();
|
|
|
|
|
|
|
|
a->B::base::x(); // expected-error{{use of undeclared identifier 'B'}}
|
|
|
|
|
|
|
|
a->A::sub::x();
|
|
|
|
a->A::B::base::x();
|
|
|
|
|
2009-12-01 06:42:35 +08:00
|
|
|
a->bad::x(); // expected-error{{type 'struct bad' is not a direct or virtual base of ''A::sub''}}
|
2009-08-06 11:17:00 +08:00
|
|
|
|
|
|
|
(*a)->foo();
|
|
|
|
(*a)->member::foo();
|
|
|
|
(*a)->A::member::foo();
|
|
|
|
}
|
|
|
|
|
|
|
|
void fun3()
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
i.foo(); // expected-error{{member reference base type 'int' is not a structure or union}}
|
|
|
|
}
|
|
|
|
|
2009-09-03 06:59:36 +08:00
|
|
|
void fun4a() {
|
|
|
|
A::sub *a;
|
|
|
|
|
|
|
|
typedef A::member base; // expected-note{{current scope}}
|
|
|
|
a->base::x(); // expected-error{{ambiguous}}
|
|
|
|
}
|
|
|
|
|
|
|
|
void fun4b() {
|
|
|
|
A::sub *a;
|
|
|
|
|
|
|
|
typedef A::B::base base;
|
|
|
|
a->base::x();
|
|
|
|
}
|
|
|
|
|
2009-08-06 11:17:00 +08:00
|
|
|
template<typename T>
|
2009-09-03 06:59:36 +08:00
|
|
|
void fun5()
|
2009-08-06 11:17:00 +08:00
|
|
|
{
|
|
|
|
T a;
|
|
|
|
a.x();
|
|
|
|
a->foo();
|
|
|
|
|
|
|
|
a.A::sub::x();
|
|
|
|
a.A::B::base::x();
|
|
|
|
a->A::member::foo();
|
|
|
|
|
2009-09-04 05:38:09 +08:00
|
|
|
a.bad::x(); // expected-error{{direct or virtual}}
|
2009-08-06 11:17:00 +08:00
|
|
|
}
|
2009-09-04 05:38:09 +08:00
|
|
|
|
2009-09-04 00:14:30 +08:00
|
|
|
void test_fun5() {
|
2009-09-04 05:38:09 +08:00
|
|
|
fun5<A::sub>(); // expected-note{{instantiation}}
|
2009-09-04 00:14:30 +08:00
|
|
|
}
|
2009-09-04 05:38:09 +08:00
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
void fun6() {
|
|
|
|
T a;
|
|
|
|
a.sub::x();
|
|
|
|
a.base::x();
|
|
|
|
a->member::foo();
|
|
|
|
a.B::base::x(); // expected-error{{use of undeclared identifier 'B'}}
|
|
|
|
}
|
|
|
|
|
|
|
|
void test_fun6() {
|
|
|
|
fun6<A::sub>(); // expected-note{{instantiation}}
|
|
|
|
}
|
|
|
|
|
2009-08-06 11:17:00 +08:00
|
|
|
}
|
2009-09-03 06:59:36 +08:00
|
|
|
|
|
|
|
// PR4703
|
|
|
|
struct a {
|
|
|
|
int a;
|
|
|
|
static int sa;
|
|
|
|
};
|
|
|
|
|
|
|
|
a a;
|
|
|
|
|
|
|
|
int a::sa = a.a;
|