2009-12-16 04:14:24 +08:00
|
|
|
// RUN: %clang_cc1 -fsyntax-only -verify %s
|
2009-10-13 13:45:19 +08:00
|
|
|
|
|
|
|
namespace A {
|
|
|
|
int VA;
|
|
|
|
void FA() {}
|
|
|
|
struct SA { int V; };
|
|
|
|
}
|
|
|
|
|
|
|
|
using A::VA;
|
|
|
|
using A::FA;
|
|
|
|
using typename A::SA;
|
|
|
|
|
2009-11-26 03:28:08 +08:00
|
|
|
int main()
|
2009-10-13 13:45:19 +08: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-26 03:28:08 +08:00
|
|
|
using E::funcE<int>; // expected-error{{using declaration can not refer to a template specialization}}
|
2009-10-13 13:45:19 +08:00
|
|
|
|
|
|
|
namespace F {
|
|
|
|
struct X;
|
|
|
|
}
|
|
|
|
|
|
|
|
using F::X;
|
|
|
|
// Should have some errors here. Waiting for implementation.
|
|
|
|
void X(int);
|
|
|
|
struct X *x;
|
2012-04-27 07:36:17 +08:00
|
|
|
|
|
|
|
|
|
|
|
namespace ShadowedTagNotes {
|
|
|
|
|
|
|
|
namespace foo {
|
|
|
|
class Bar {};
|
|
|
|
}
|
|
|
|
|
2012-04-28 02:26:49 +08:00
|
|
|
void Bar(int); // expected-note{{class 'Bar' is hidden by a non-type declaration of 'Bar' here}}
|
2012-04-27 07:36:17 +08:00
|
|
|
using foo::Bar;
|
|
|
|
|
|
|
|
void ambiguity() {
|
|
|
|
const Bar *x; // expected-error{{must use 'class' tag to refer to type 'Bar' in this scope}}
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace ShadowedTagNotes
|