]> git.ipfire.org Git - thirdparty/gcc.git/commit
c++: CTAD within template argument [PR102933]
authorPatrick Palka <ppalka@redhat.com>
Thu, 28 Oct 2021 14:46:46 +0000 (10:46 -0400)
committerPatrick Palka <ppalka@redhat.com>
Thu, 28 Oct 2021 14:46:46 +0000 (10:46 -0400)
commitf70f17d03630fd948bc15a646ebe7e784125c4d4
treec8a7da7cf918f8f6d565f41a3962aa6c38655759
parente5ddbbf992b909d8e38851bd3179d29389e6ac97
c++: CTAD within template argument [PR102933]

Here when checking for erroneous occurrences of 'auto' inside a template
argument (which is allowed by the concepts TS for class templates),
extract_autos_r picks up the CTAD placeholder for X{T{0}} which causes
check_auto_in_tmpl_args to reject this valid template argument.  This
patch fixes this by making extract_autos_r ignore CTAD placeholders.

However, it seems we don't need to call check_auto_in_tmpl_args at all
outside of the concepts TS since using 'auto' as a type-id is otherwise
rejected more generally at parse time.  So this patch makes the function
just exit early if !flag_concepts_ts.

Similarly, I think the concepts code paths in do_auto_deduction and
type_uses_auto are only necessary for the concepts TS, so this patch
also restricts these code paths accordingly.

PR c++/102933

gcc/cp/ChangeLog:

* parser.c (cp_parser_simple_type_specifier): Adjust diagnostic
for using auto in parameter declaration.
* pt.c (extract_autos_r): Ignore CTAD placeholders.
(extract_autos): Use range-based for.
(do_auto_deduction): Use extract_autos only for the concepts TS
and not also for standard concepts.
(type_uses_auto): Likewise with for_each_template_parm.
(check_auto_in_tmpl_args): Just return false outside of the
concepts TS.  Simplify.

gcc/testsuite/ChangeLog:

* g++.dg/cpp2a/nontype-class50.C: New test.
* g++.dg/cpp2a/nontype-class50a.C: New test.
gcc/cp/parser.c
gcc/cp/pt.c
gcc/testsuite/g++.dg/cpp2a/nontype-class50.C [new file with mode: 0644]
gcc/testsuite/g++.dg/cpp2a/nontype-class50a.C [new file with mode: 0644]