diff options
author | Marek Polacek <polacek@redhat.com> | 2024-09-23 12:19:40 -0400 |
---|---|---|
committer | Marek Polacek <polacek@redhat.com> | 2024-09-23 15:24:07 -0400 |
commit | 4700ad1c78ccd7767f846802fca148b2ea9a1852 (patch) | |
tree | d1766e6f30630745d78b984d82746f1d16300ca5 | |
parent | c1fb78fb03caede01b02a1ebb3275ac98343d468 (diff) | |
download | gcc-4700ad1c78ccd7767f846802fca148b2ea9a1852.zip gcc-4700ad1c78ccd7767f846802fca148b2ea9a1852.tar.gz gcc-4700ad1c78ccd7767f846802fca148b2ea9a1852.tar.bz2 |
c++: diagnose this specifier in requires expr [PR116798]
We don't detect an explicit object parameter in a requires expression.
We can get there by way of requires-expression -> requirement-parameter-list
-> parameter-declaration-clause -> ... -> parameter-declaration with
this[opt]. But [dcl.fct]/5 doesn't allow an explicit object parameter
in this context. So let's fix it like r14-9033 and not like r14-8832.
PR c++/116798
gcc/cp/ChangeLog:
* parser.cc (cp_parser_parameter_declaration): Detect an explicit
object parameter in a requires expression.
gcc/testsuite/ChangeLog:
* g++.dg/cpp23/explicit-obj-diagnostics12.C: New test.
Reviewed-by: Jason Merrill <jason@redhat.com>
-rw-r--r-- | gcc/cp/parser.cc | 11 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/cpp23/explicit-obj-diagnostics12.C | 10 |
2 files changed, 18 insertions, 3 deletions
diff --git a/gcc/cp/parser.cc b/gcc/cp/parser.cc index 4dd9474..dbc6070 100644 --- a/gcc/cp/parser.cc +++ b/gcc/cp/parser.cc @@ -25982,10 +25982,15 @@ cp_parser_parameter_declaration (cp_parser *parser, bool xobj_param_p = decl_spec_seq_has_spec_p (&decl_specifiers, ds_this); - if (xobj_param_p && template_parm_p) + if (xobj_param_p + && (template_parm_p || current_binding_level->requires_expression)) { - error_at (decl_specifiers.locations[ds_this], - "%<this%> specifier in template parameter declaration"); + if (template_parm_p) + error_at (decl_specifiers.locations[ds_this], + "%<this%> specifier in template parameter declaration"); + else + error_at (decl_specifiers.locations[ds_this], + "%<this%> specifier in a requires-expression parameter"); xobj_param_p = false; decl_specifiers.locations[ds_this] = 0; } diff --git a/gcc/testsuite/g++.dg/cpp23/explicit-obj-diagnostics12.C b/gcc/testsuite/g++.dg/cpp23/explicit-obj-diagnostics12.C new file mode 100644 index 0000000..ec0aced --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp23/explicit-obj-diagnostics12.C @@ -0,0 +1,10 @@ +// PR c++/116798 +// { dg-do compile { target c++23 } } + +template<typename T> +concept C = requires(this T u, // { dg-error "'this' specifier in a requires-expression parameter" } + this T v) { // { dg-error "'this' specifier in a requires-expression parameter" } + u + v; +}; + +static_assert(C<int>); |