diff options
author | Mark Mitchell <mark@codesourcery.com> | 2004-08-02 06:25:36 +0000 |
---|---|---|
committer | Mark Mitchell <mmitchel@gcc.gnu.org> | 2004-08-02 06:25:36 +0000 |
commit | b1cc95ce4c15c335589c5e0077c29c06c739e730 (patch) | |
tree | c3d8dbd637ffc5e31556926ff4cb38f427e0d90a /gcc/testsuite | |
parent | e9475fa369a6f1491864fc3f768a08573a4a5456 (diff) | |
download | gcc-b1cc95ce4c15c335589c5e0077c29c06c739e730.zip gcc-b1cc95ce4c15c335589c5e0077c29c06c739e730.tar.gz gcc-b1cc95ce4c15c335589c5e0077c29c06c739e730.tar.bz2 |
re PR c++/16224 (internal compiler error: in write_unscoped_name (template/namespace))
PR c++/16224
* name-lookup.c (decl_namespace): Remove.
(current_decl_namespace): Use decl_namespace_context instead of
decl_namespace.
(push_decl_namespace): Likewise.
(arg_assoc_class): Likewise.
(arg_assoc_type): Likewise.
* pt.c (check_specialization_namespace): New function.
(maybe_process_partial_specialization): Use it.
(register_specialization): Likewise.
PR c++/16224
* g++.dg/template/spec17.C: New test.
* g++.old-deja/g++.ns/template13.C: Remove XFAIL.
* g++.old-deja/g++.pt/lookup10.C: Add dg-error marker.
From-SVN: r85431
Diffstat (limited to 'gcc/testsuite')
-rw-r--r-- | gcc/testsuite/ChangeLog | 7 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/template/spec17.C | 11 | ||||
-rw-r--r-- | gcc/testsuite/g++.old-deja/g++.ns/template13.C | 5 | ||||
-rw-r--r-- | gcc/testsuite/g++.old-deja/g++.pt/lookup10.C | 4 |
4 files changed, 23 insertions, 4 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index e394b1f..eb04ff1 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,10 @@ +2004-08-01 Mark Mitchell <mark@codesourcery.com> + + PR c++/16224 + * g++.dg/template/spec17.C: New test. + * g++.old-deja/g++.ns/template13.C: Remove XFAIL. + * g++.old-deja/g++.pt/lookup10.C: Add dg-error marker. + 2004-08-02 David Billinghurst PR fortran/16292 diff --git a/gcc/testsuite/g++.dg/template/spec17.C b/gcc/testsuite/g++.dg/template/spec17.C new file mode 100644 index 0000000..2375576 --- /dev/null +++ b/gcc/testsuite/g++.dg/template/spec17.C @@ -0,0 +1,11 @@ +// PR c++/16224 + +namespace io { + template <typename> int foo(); // { dg-error "" } +} + +using namespace io; + +template<> int foo<int>(); // { dg-error "" } + +int a = foo<int>(); diff --git a/gcc/testsuite/g++.old-deja/g++.ns/template13.C b/gcc/testsuite/g++.old-deja/g++.ns/template13.C index d7e4b79..058d7b9 100644 --- a/gcc/testsuite/g++.old-deja/g++.ns/template13.C +++ b/gcc/testsuite/g++.old-deja/g++.ns/template13.C @@ -2,8 +2,9 @@ // Templates defined outside must be declared inside namespace bar { + // trick it to provide some prior declaration template<class T> - void foo(); // trick it to provide some prior declaration + void foo(); // { dg-error "definition" } template<class T>class X; // { dg-error "" } previous declaration } @@ -15,7 +16,7 @@ bar::foo(T const &a) } template<> void bar::foo<int>() -{ // { dg-error "" "" { xfail *-*-* } } not declared in bar - +{ // { dg-error "" } } template<class T,class U> diff --git a/gcc/testsuite/g++.old-deja/g++.pt/lookup10.C b/gcc/testsuite/g++.old-deja/g++.pt/lookup10.C index c0b4389..1c04250 100644 --- a/gcc/testsuite/g++.old-deja/g++.pt/lookup10.C +++ b/gcc/testsuite/g++.old-deja/g++.pt/lookup10.C @@ -13,8 +13,8 @@ namespace Outer { namespace Core = Core_Real; namespace Core_Real { - template<class T> void Foo (T *) {} + template<class T> void Foo (T *) {} // { dg-error "definition" } } - template<> void Core::Foo<> (Render_Real::Type *) {} + template<> void Core::Foo<> (Render_Real::Type *) {} // { dg-error "" } } |