From: Marek Polacek Date: Thu, 8 Jun 2023 18:07:44 +0000 (-0400) Subject: c++: fix error reporting routines re-entered ICE [PR110175] X-Git-Tag: basepoints/gcc-15~7972 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=4de22e25918f6fe40184c444ba6d81b19b806e26;p=thirdparty%2Fgcc.git c++: fix error reporting routines re-entered ICE [PR110175] Here we get the "error reporting routines re-entered" ICE because of an unguarded use of warning_at. While at it, I added a check for a warning_at just above it. PR c++/110175 gcc/cp/ChangeLog: * typeck.cc (cp_build_unary_op): Check tf_warning before warning. gcc/testsuite/ChangeLog: * g++.dg/cpp0x/decltype-110175.C: New test. --- diff --git a/gcc/cp/typeck.cc b/gcc/cp/typeck.cc index da591dafc8ff..859b133a18d8 100644 --- a/gcc/cp/typeck.cc +++ b/gcc/cp/typeck.cc @@ -7561,7 +7561,8 @@ cp_build_unary_op (enum tree_code code, tree xarg, bool noconvert, /* [depr.volatile.type] "Postfix ++ and -- expressions and prefix ++ and -- expressions of volatile-qualified arithmetic and pointer types are deprecated." */ - if (TREE_THIS_VOLATILE (arg) || CP_TYPE_VOLATILE_P (TREE_TYPE (arg))) + if ((TREE_THIS_VOLATILE (arg) || CP_TYPE_VOLATILE_P (TREE_TYPE (arg))) + && (complain & tf_warning)) warning_at (location, OPT_Wvolatile, "%qs expression of %-qualified type is " "deprecated", @@ -7592,7 +7593,7 @@ cp_build_unary_op (enum tree_code code, tree xarg, bool noconvert, return error_mark_node; } /* Otherwise, [depr.incr.bool] says this is deprecated. */ - else + else if (complain & tf_warning) warning_at (location, OPT_Wdeprecated, "use of an operand of type %qT " "in % is deprecated", diff --git a/gcc/testsuite/g++.dg/cpp0x/decltype-110175.C b/gcc/testsuite/g++.dg/cpp0x/decltype-110175.C new file mode 100644 index 000000000000..39643cafcf81 --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp0x/decltype-110175.C @@ -0,0 +1,6 @@ +// PR c++/110175 +// { dg-do compile { target c++11 } } + +template auto f(T t) -> decltype(++t) { return t; } // { dg-warning "reference" "" { target c++14_down } } +void f(...) {} +void g() { f(true); }