diff options
author | Patrick Palka <ppalka@redhat.com> | 2023-09-19 08:21:05 -0400 |
---|---|---|
committer | Patrick Palka <ppalka@redhat.com> | 2023-09-19 08:21:05 -0400 |
commit | ddd064e3571c4a9e6258c75eba65585a07367712 (patch) | |
tree | 2be793bda1a76e2655f7487acf8f9c7bfe9344e1 /gcc/cp/tree.cc | |
parent | 131c1df8d901385c8622aa067c5890458005d1a9 (diff) | |
download | gcc-ddd064e3571c4a9e6258c75eba65585a07367712.zip gcc-ddd064e3571c4a9e6258c75eba65585a07367712.tar.gz gcc-ddd064e3571c4a9e6258c75eba65585a07367712.tar.bz2 |
c++: constness of decltype of NTTP object [PR99631]
This corrects resolving decltype of a (class) NTTP object as per
[dcl.type.decltype]/1.2 and [temp.param]/6 in the type-dependent case.
Note that in the non-dependent case we resolve the decltype ahead of
time, in which case finish_decltype_type drops the const VIEW_CONVERT_EXPR
wrapper around the TEMPLATE_PARM_INDEX, and the latter has the desired
non-const type.
In the type-dependent case, at instantiation time tsubst drops the
VIEW_CONVERT_EXPR since the substituted NTTP is the already-const object
created by get_template_parm_object. So in this case finish_decltype_type
sees the const object, which this patch now adds special handling for.
PR c++/99631
gcc/cp/ChangeLog:
* semantics.cc (finish_decltype_type): For an NTTP object,
return its type modulo cv-quals.
gcc/testsuite/ChangeLog:
* g++.dg/cpp2a/nontype-class60.C: New test.
Diffstat (limited to 'gcc/cp/tree.cc')
0 files changed, 0 insertions, 0 deletions