From: Giovanni Bajo Date: Mon, 2 Feb 2004 01:11:03 +0000 (+0000) Subject: re PR c++/13957 (Insufficient diagnostic for dependent expression parsed as non-type... X-Git-Tag: releases/gcc-4.0.0~10471 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=9febc4e8def2dbed004c56126ccd6218ffb6fd38;p=thirdparty%2Fgcc.git re PR c++/13957 (Insufficient diagnostic for dependent expression parsed as non-type but instantiated as type) PR c++/13957 * g++.dg/template/non-type-template-argument-1.C, g++.dg/template/qualified-id1.C: Update dg-error marks. * g++.dg/template/nontype6.C: New test. From-SVN: r77091 --- diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index afd9ce64f244..87fe8b74ef5b 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,10 @@ +2004-02-01 Giovanni Bajo + + PR c++/13957 + * g++.dg/template/non-type-template-argument-1.C, + g++.dg/template/qualified-id1.C: Update dg-error marks. + * g++.dg/template/nontype6.C: New test. + 2004-02-01 Roger Sayle * gcc.dg/builtins-1.c: Also test for __builtin_signbit{,f,l}. diff --git a/gcc/testsuite/g++.dg/template/non-type-template-argument-1.C b/gcc/testsuite/g++.dg/template/non-type-template-argument-1.C index 273017635c3f..9d400d5b1043 100644 --- a/gcc/testsuite/g++.dg/template/non-type-template-argument-1.C +++ b/gcc/testsuite/g++.dg/template/non-type-template-argument-1.C @@ -6,7 +6,7 @@ template struct C {}; template struct D { - C c; // { dg-error "names a type" } + C c; // { dg-error "parsed as a non-type|if a type is meant" } }; -D d; // { dg-error "" } +D d; // { dg-error "instantiated from here" } diff --git a/gcc/testsuite/g++.dg/template/nontype6.C b/gcc/testsuite/g++.dg/template/nontype6.C new file mode 100644 index 000000000000..43470ccdb1df --- /dev/null +++ b/gcc/testsuite/g++.dg/template/nontype6.C @@ -0,0 +1,19 @@ +// { dg-do compile } +// Origin: +// PR c++/13957: Improved error message for type in template (when non-type +// is expected). + +template +struct A +{ + typedef int type; +}; + +template +void func(void) +{ + (void)A::type(); // { dg-error "if a type is meant" } +// { dg-error "parsed as a non-type" "" { target *-*-* } 15 } +} + +template void func(void); // { dg-error "instantiated from here" } diff --git a/gcc/testsuite/g++.dg/template/qualified-id1.C b/gcc/testsuite/g++.dg/template/qualified-id1.C index bbe23c2743b3..967764281c03 100644 --- a/gcc/testsuite/g++.dg/template/qualified-id1.C +++ b/gcc/testsuite/g++.dg/template/qualified-id1.C @@ -16,8 +16,8 @@ template <> struct A::B {}; template void foo() { - T::C (); // { dg-error "names a type" "" } - T::template B(); // { dg-error "names a type" "" } + T::C (); // { dg-error "parsed as a non-type|if a type is meant" "" } + T::template B(); // { dg-error "parsed as a non-type|if a type is meant" "" } } void bar()