diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 981976f2821bb7495ac07b7a8fa2d635dc55a2f0..53b2953320a71e8b1866aee5ac5f7131dc34f96c 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2006-01-19 Volker Reichelt <reichelt@igpm.rwth-aachen.de> + + PR c++/25854 + * pt.c (maybe_process_partial_specialization): Return early on + error_mark_node. + 2006-01-19 Volker Reichelt <reichelt@igpm.rwth-aachen.de> PR c++/16829 diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index 23c84cde0daad73546bd0b83b02819770c28247a..236145763addfda4a7dc51de3e4ec51a7d8fdc0b 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -678,8 +678,12 @@ check_explicit_instantiation_namespace (tree spec) void maybe_process_partial_specialization (tree type) { - /* TYPE maybe an ERROR_MARK_NODE. */ - tree context = TYPE_P (type) ? TYPE_CONTEXT (type) : NULL_TREE; + tree context; + + if (type == error_mark_node) + return; + + context = TYPE_CONTEXT (type); if (CLASS_TYPE_P (type) && CLASSTYPE_USE_TEMPLATE (type)) { diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index f39f40f89ad1ce3f3d1637a6671c3fa52afd0757..4e4c7e0c683914ca102089511bee2b55d3f88b85 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2006-01-19 Volker Reichelt <reichelt@igpm.rwth-aachen.de> + + PR c++/25854 + * g++.dg/template/spec28.C: New test. + 2006-01-19 Andrew Pinski <pinskia@physics.uc.edu> * objc.dg/gnu-encoding/struct-layout-encoding-1_generate.c (switchfiles): diff --git a/gcc/testsuite/g++.dg/template/spec28.C b/gcc/testsuite/g++.dg/template/spec28.C new file mode 100644 index 0000000000000000000000000000000000000000..f0bb22caeb4041ada4d584b0ee2c4f89fc127941 --- /dev/null +++ b/gcc/testsuite/g++.dg/template/spec28.C @@ -0,0 +1,6 @@ +// PR c++/25854 +// Bad diagnostic +// { dg-do compile } + +template<typename> struct A {}; // { dg-error "provided" } +template<> struct A<> {}; // { dg-error "wrong number" }