1 // RUN: %clang_cc1 -fsyntax-only -verify %s
2
3 namespace A {
4 int VA;
FA()5 void FA() {}
6 struct SA { int V; };
7 }
8
9 using A::VA;
10 using A::FA;
11 using typename A::SA;
12
main()13 int main()
14 {
15 VA = 1;
16 FA();
17 SA x; //Still needs handling.
18 }
19
20 struct B {
fB21 void f(char){};
gB22 void g(char){};
23 };
24 struct D : B {
25 using B::f;
26 void f(int);
27 void g(int);
28 };
f(int)29 void D::f(int) { f('c'); } // calls B::f(char)
g(int)30 void D::g(int) { g('c'); } // recursively calls D::g(int)
31
32 namespace E {
funcE(TYPE arg)33 template <typename TYPE> int funcE(TYPE arg) { return(arg); }
34 }
35
36 using E::funcE<int>; // expected-error{{using declaration can not refer to a template specialization}}
37
38 namespace F {
39 struct X;
40 }
41
42 using F::X;
43 // Should have some errors here. Waiting for implementation.
44 void X(int);
45 struct X *x;
46
47
48 namespace ShadowedTagNotes {
49
50 namespace foo {
51 class Bar {};
52 }
53
54 void Bar(int); // expected-note{{class 'Bar' is hidden by a non-type declaration of 'Bar' here}}
55 using foo::Bar;
56
ambiguity()57 void ambiguity() {
58 const Bar *x; // expected-error{{must use 'class' tag to refer to type 'Bar' in this scope}}
59 }
60
61 } // namespace ShadowedTagNotes
62