From: H.J. Lu Date: Wed, 18 Mar 2009 14:56:45 +0000 (+0000) Subject: re PR c++/39425 (gcc loops after reporting template instantiation errors) X-Git-Tag: releases/gcc-4.4.0~237 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=367bdb8d6b5d4b4dac469c46463976675e9adcb6;p=thirdparty%2Fgcc.git re PR c++/39425 (gcc loops after reporting template instantiation errors) gcc/cp/ 2009-03-18 H.J. Lu PR c++/39425 * parser.c (cp_parser_explicit_specialization): Don't skip the rest of the specialization when begin_specialization returns false. gcc/testsuite/ 2009-03-18 H.J. Lu PR c++/39425 * g++.dg/template/pr39425.C: New. * g++.dg/template/spec33.C: Updated. From-SVN: r144932 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 1f5dd9d75f50..ecf1bc634cec 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,10 @@ +2009-03-18 H.J. Lu + + PR c++/39425 + * parser.c (cp_parser_explicit_specialization): Don't skip the + rest of the specialization when begin_specialization returns + false. + 2009-03-17 Jason Merrill * decl.c (grokfndecl): Set DECL_CONTEXT on parms. diff --git a/gcc/cp/parser.c b/gcc/cp/parser.c index 4c6fd4a78c59..7206af2e4a44 100644 --- a/gcc/cp/parser.c +++ b/gcc/cp/parser.c @@ -10883,7 +10883,6 @@ cp_parser_explicit_specialization (cp_parser* parser) if (!begin_specialization ()) { end_specialization (); - cp_parser_skip_to_end_of_block_or_statement (parser); return; } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index b59350c54447..c9d0832fbc35 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,10 @@ +2009-03-18 H.J. Lu + + PR c++/39425 + * g++.dg/template/pr39425.C: New. + + * g++.dg/template/spec33.C: Updated. + 2009-03-17 Jason Merrill * g++.dg/cpp0x/auto6.C, auto12.C: Update mangling. diff --git a/gcc/testsuite/g++.dg/template/pr39425.C b/gcc/testsuite/g++.dg/template/pr39425.C new file mode 100644 index 000000000000..a063e05c2c71 --- /dev/null +++ b/gcc/testsuite/g++.dg/template/pr39425.C @@ -0,0 +1,18 @@ +// PR c++/39425 +// { dg-do compile } + +class a { + + template + struct _rec { + static const char size = _rec< (s >> 1) >::size; + }; + + template<> // { dg-error "explicit" } + struct _rec <0> { + static const char size = 0; + }; + + static const unsigned int value = _rec < 1 >::size; + +} // { dg-error "unqualified-id" } diff --git a/gcc/testsuite/g++.dg/template/spec33.C b/gcc/testsuite/g++.dg/template/spec33.C index 809d4f012c1a..7b7a7519829a 100644 --- a/gcc/testsuite/g++.dg/template/spec33.C +++ b/gcc/testsuite/g++.dg/template/spec33.C @@ -3,5 +3,5 @@ struct A { template static void foo () {} - template<> static void foo<0>() {} // { dg-error "explicit" } + template<> static void foo<0>() {} // { dg-error "explicit|template" } };