mirror of
git://gcc.gnu.org/git/gcc.git
synced 2025-04-04 02:40:27 +08:00
re PR c++/2294 (using declaration confusion)
PR c++/2294 * g++.dg/lookup/using9.c: New test. From-SVN: r73621
This commit is contained in:
parent
584fb00b96
commit
8ffc2e370d
@ -1,3 +1,8 @@
|
||||
2003-11-14 Giovanni Bajo <giovannibajo@libero.it>
|
||||
|
||||
PR c++/2294
|
||||
* g++.dg/lookup/using9.c: New test.
|
||||
|
||||
2003-11-14 Mark Mitchell <mark@codesourcery.com>
|
||||
|
||||
PR c++/12762
|
||||
|
30
gcc/testsuite/g++.dg/lookup/using9.C
Normal file
30
gcc/testsuite/g++.dg/lookup/using9.C
Normal file
@ -0,0 +1,30 @@
|
||||
// { dg-do compile }
|
||||
// Origin: C++ Standard Draft (7.3.3/12)
|
||||
// PR c++/2294: using declarations should not conflict, but only cause
|
||||
// an ambiguous overload set to be created.
|
||||
|
||||
namespace B {
|
||||
void f(int); // { dg-error "note" }
|
||||
void f(double); // { dg-error "note" }
|
||||
}
|
||||
|
||||
namespace C {
|
||||
void f(int); // { dg-error "note" }
|
||||
void f(double); // { dg-error "note" }
|
||||
void f(char); // { dg-error "note" }
|
||||
}
|
||||
|
||||
void h()
|
||||
{
|
||||
using B::f;
|
||||
using C::f;
|
||||
f('h');
|
||||
f(1); // { dg-error "ambiguous" }
|
||||
void f(int); // { dg-error "previous using declaration" }
|
||||
}
|
||||
|
||||
void m()
|
||||
{
|
||||
void f(int);
|
||||
using B::f; // { dg-error "already declared" }
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user