From: Patrick Palka Date: Mon, 19 Feb 2024 16:34:45 +0000 (-0500) Subject: c++: compound-requirement partial substitution [PR113966] X-Git-Tag: releases/gcc-13.3.0~172 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=265f207a46bc38b4519007b175c3dd0cf434a2ca;p=thirdparty%2Fgcc.git c++: compound-requirement partial substitution [PR113966] When partially substituting a requires-expr, we don't want to perform any additional checks beyond the substitution itself so as to minimize checking requirements out of order. So don't check the return-type-req of a compound-requirement during partial substitution. And don't check the noexcept condition either since we can't do that on templated trees. PR c++/113966 gcc/cp/ChangeLog: * constraint.cc (tsubst_compound_requirement): Don't check the noexcept condition or the return-type-requirement when partially substituting. gcc/testsuite/ChangeLog: * g++.dg/cpp2a/concepts-friend17.C: New test. Reviewed-by: Jason Merrill (cherry picked from commit 3a6f3354eaaf38b5e6be41e4ebf521d299593a6e) --- diff --git a/gcc/cp/constraint.cc b/gcc/cp/constraint.cc index 971619eabea7..83df57dc6fd7 100644 --- a/gcc/cp/constraint.cc +++ b/gcc/cp/constraint.cc @@ -2142,7 +2142,8 @@ tsubst_compound_requirement (tree t, tree args, sat_info info) /* Check the noexcept condition. */ bool noexcept_p = COMPOUND_REQ_NOEXCEPT_P (t); - if (noexcept_p && !expr_noexcept_p (expr, quiet.complain)) + if (noexcept_p && !processing_template_decl + && !expr_noexcept_p (expr, quiet.complain)) { if (info.diagnose_unsatisfaction_p ()) inform (loc, "%qE is not %", expr); @@ -2156,7 +2157,7 @@ tsubst_compound_requirement (tree t, tree args, sat_info info) return error_mark_node; /* Check expression against the result type. */ - if (type) + if (type && !processing_template_decl) { if (tree placeholder = type_uses_auto (type)) { diff --git a/gcc/testsuite/g++.dg/cpp2a/concepts-friend17.C b/gcc/testsuite/g++.dg/cpp2a/concepts-friend17.C new file mode 100644 index 000000000000..9b5091f14a81 --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp2a/concepts-friend17.C @@ -0,0 +1,15 @@ +// PR c++/113966 +// { dg-do compile { target c++20 } } + +template concept C = T::value; + +template +struct A { + template requires U::value || requires { { T() } -> C; } + friend void f(A, U) { } + + template requires requires { { g(U()) } noexcept; } + friend void f(A, U, U) { } +}; + +template struct A;