From: Marek Polacek Date: Fri, 11 Oct 2019 20:44:02 +0000 (+0000) Subject: PR c++/92049 - extra error with -fchecking=2. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=c6c3f55699d316da38496de1328f6e09a46deed8;p=gcc.git PR c++/92049 - extra error with -fchecking=2. The concepts merge brought this bit @@ -26326,9 +26559,9 @@ build_non_dependent_expr (tree expr) unexpected recursive instantiations. */ && !parsing_nsdmi () /* Don't do this during concept expansion either and for - the same reason. */ - && !expanding_concept ()) - fold_non_dependent_expr (expr, tf_none); + the same reason. */ + && !parsing_constraint_expression_p ()) + fold_non_dependent_expr (expr); STRIP_ANY_LOCATION_WRAPPER (expr); (which I'm not finding in the ChangeLog). Dropping tf_none means that fold_non_dependent_expr will use tf_warning_or_error by default, and in this test that causes an error: template struct cond; template struct S { void f(int i) { cond<__builtin_constant_p(i)>(); } }; S<1> s; where it complains that cond is incomplete. Which it is, but we're not actually instantiating the function f, so issuing an error seems overzealous (though not wrong), and it breaks a bunch of tests. This patch brings that tf_none back. We will still complain if we do instantiate f. * pt.c (build_non_dependent_expr): Call fold_non_dependent_expr with tf_none. * g++.dg/template/builtin2.C: New test. From-SVN: r276906 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 49fb50db2d2..02a330d772e 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2019-10-11 Marek Polacek + + PR c++/92049 - extra error with -fchecking=2. + * pt.c (build_non_dependent_expr): Call fold_non_dependent_expr + with tf_none. + 2019-10-11 Paolo Carlini * typeck.c (cp_build_binary_op): Do not handle RROTATE_EXPR and diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index 7fecc03f6cc..773eb43d934 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -27059,7 +27059,7 @@ build_non_dependent_expr (tree expr) /* Don't do this during concept processing either and for the same reason. */ && !processing_constraint_expression_p ()) - fold_non_dependent_expr (expr); + fold_non_dependent_expr (expr, tf_none); STRIP_ANY_LOCATION_WRAPPER (expr); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index cc1a57b7097..bbcea404db4 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2019-10-11 Marek Polacek + + PR c++/92049 - extra error with -fchecking=2. + * g++.dg/template/builtin2.C: New test. + 2019-10-11 Jim Wilson PR rtl-optimization/91860 diff --git a/gcc/testsuite/g++.dg/template/builtin2.C b/gcc/testsuite/g++.dg/template/builtin2.C new file mode 100644 index 00000000000..4e9089a2313 --- /dev/null +++ b/gcc/testsuite/g++.dg/template/builtin2.C @@ -0,0 +1,5 @@ +// PR c++/92049 - extra error with -fchecking=2. +// { dg-do compile { target c++11 } } +// { dg-additional-options "-fchecking=2" } + +#include "builtin1.C"