2009-12-15 20:14:24 +00:00
|
|
|
// RUN: %clang_cc1 -fsyntax-only -verify %s
|
2009-10-13 05:45:19 +00:00
|
|
|
|
|
|
|
namespace A {
|
|
|
|
int VA;
|
|
|
|
void FA() {}
|
|
|
|
struct SA { int V; };
|
|
|
|
}
|
|
|
|
|
|
|
|
using A::VA;
|
|
|
|
using A::FA;
|
|
|
|
using typename A::SA;
|
|
|
|
|
2009-11-25 19:28:08 +00:00
|
|
|
int main()
|
2009-10-13 05:45:19 +00:00
|
|
|
{
|
|
|
|
VA = 1;
|
|
|
|
FA();
|
|
|
|
SA x; //Still needs handling.
|
|
|
|
}
|
|
|
|
|
|
|
|
struct B {
|
|
|
|
void f(char){};
|
|
|
|
void g(char){};
|
|
|
|
};
|
|
|
|
struct D : B {
|
|
|
|
using B::f;
|
|
|
|
void f(int);
|
|
|
|
void g(int);
|
|
|
|
};
|
|
|
|
void D::f(int) { f('c'); } // calls B::f(char)
|
|
|
|
void D::g(int) { g('c'); } // recursively calls D::g(int)
|
|
|
|
|
|
|
|
namespace E {
|
|
|
|
template <typename TYPE> int funcE(TYPE arg) { return(arg); }
|
|
|
|
}
|
|
|
|
|
2009-11-25 19:28:08 +00:00
|
|
|
using E::funcE<int>; // expected-error{{using declaration can not refer to a template specialization}}
|
2009-10-13 05:45:19 +00:00
|
|
|
|
|
|
|
namespace F {
|
|
|
|
struct X;
|
|
|
|
}
|
|
|
|
|
|
|
|
using F::X;
|
|
|
|
// Should have some errors here. Waiting for implementation.
|
|
|
|
void X(int);
|
|
|
|
struct X *x;
|