aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite
diff options
context:
space:
mode:
authorMark Mitchell <mark@codesourcery.com>2004-08-02 06:25:36 +0000
committerMark Mitchell <mmitchel@gcc.gnu.org>2004-08-02 06:25:36 +0000
commitb1cc95ce4c15c335589c5e0077c29c06c739e730 (patch)
treec3d8dbd637ffc5e31556926ff4cb38f427e0d90a /gcc/testsuite
parente9475fa369a6f1491864fc3f768a08573a4a5456 (diff)
downloadgcc-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/ChangeLog7
-rw-r--r--gcc/testsuite/g++.dg/template/spec17.C11
-rw-r--r--gcc/testsuite/g++.old-deja/g++.ns/template13.C5
-rw-r--r--gcc/testsuite/g++.old-deja/g++.pt/lookup10.C4
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 "" }
}