aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/arm/macro_defs2.c
diff options
context:
space:
mode:
authorJason Merrill <jason@redhat.com>2025-01-29 05:15:00 -0500
committerJason Merrill <jason@redhat.com>2025-04-04 15:40:08 -0400
commit25992d8daff60726a247ec7850d540aed5335639 (patch)
treeaf59650b5a8b270d61e512f5efe618402900b94c /gcc/testsuite/gcc.target/arm/macro_defs2.c
parent2a36d22ab52d6ffce9a1fcaf7aca83336679e111 (diff)
downloadgcc-master.zip
gcc-master.tar.gz
gcc-master.tar.bz2
c++: lambda in requires outside template [PR99546]HEADtrunkmaster
Since r10-7441 we set processing_template_decl in a requires-expression so that we can use tsubst_expr to evaluate the requirements, but that confuses lambdas terribly; begin_lambda_type silently returns error_mark_node and we continue into other failures. This patch clears processing_template_decl again while we're defining the closure and op() function, so it only remains set while parsing the introducer (i.e. any init-captures) and building the resulting object. This properly avoids trying to create another lambda in tsubst_lambda_expr. PR c++/99546 PR c++/113925 PR c++/106976 PR c++/109961 PR c++/117336 gcc/cp/ChangeLog: * lambda.cc (build_lambda_object): Handle fake requires-expr processing_template_decl. * parser.cc (cp_parser_lambda_expression): Likewise. gcc/testsuite/ChangeLog: * g++.dg/cpp2a/lambda-requires2.C: New test. * g++.dg/cpp2a/lambda-requires3.C: New test. * g++.dg/cpp2a/lambda-requires4.C: New test. * g++.dg/cpp2a/lambda-requires5.C: New test.
Diffstat (limited to 'gcc/testsuite/gcc.target/arm/macro_defs2.c')
0 files changed, 0 insertions, 0 deletions