From: Jason Merrill Date: Wed, 30 Dec 2020 18:07:57 +0000 (-0500) Subject: c++: Add using-declaration testcase X-Git-Tag: basepoints/gcc-13~8012 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=f03973251db33ad8d08c03ac570cd378e46d3a20;p=thirdparty%2Fgcc.git c++: Add using-declaration testcase gcc/testsuite/ChangeLog: * g++.dg/lookup/using-decl1.C: New test. --- diff --git a/gcc/testsuite/g++.dg/lookup/using-decl1.C b/gcc/testsuite/g++.dg/lookup/using-decl1.C new file mode 100644 index 000000000000..7ccb4fc91812 --- /dev/null +++ b/gcc/testsuite/g++.dg/lookup/using-decl1.C @@ -0,0 +1,38 @@ +// Testcase from [namespace.udecl] updated by P1787 + +namespace A { + int x; + int f(int); + int g; + void h(); +} + +namespace B { + int i; + struct g { }; + struct x { }; + void f(int); + void f(double); + void g(char); // OK: hides struct g +} + +void func() { + int i; + using B::i; // { dg-error "" } i conflicts + void f(char); + using B::f; // OK: each f is a function + using A::f; // OK, but interferes with B::f(int) + f(1); // { dg-error "" } ambiguous + static_cast(f)(1); // OK: calls A::f + f(3.5); // calls B::f(double) + using B::g; + g('a'); // calls B::g(char) + struct g g1; // g1 has class type B::g + using A::g; // { dg-error "" } conflicts with B::g + void h(); + using A::h; // { dg-error "" } conflicts + using B::x; + using A::x; // OK: hides struct B::x + x = 99; // assigns to A::x + struct x x1; // x1 has class type B::x +}