aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJason Merrill <jason@redhat.com>2024-02-01 16:54:39 -0500
committerJason Merrill <jason@redhat.com>2024-02-01 22:21:02 -0500
commit0b786ff38ab398087820d91241e030a28c451df9 (patch)
treeac3c59058e730f4a2719e30fddd80e881d97aef2 /gcc
parente0701f8f7b6dcddb299eb5345e510cf9ea419150 (diff)
downloadgcc-0b786ff38ab398087820d91241e030a28c451df9.zip
gcc-0b786ff38ab398087820d91241e030a28c451df9.tar.gz
gcc-0b786ff38ab398087820d91241e030a28c451df9.tar.bz2
c++: variable template array of unknown bound [PR113638]
When we added variable templates, we didn't extend the VAR_HAD_UNKNOWN_BOUND handling for class template static data members to handle them as well. PR c++/113638 gcc/cp/ChangeLog: * cp-tree.h: Adjust comment. * pt.cc (instantiate_template): Set VAR_HAD_UNKNOWN_BOUND for variable template. gcc/testsuite/ChangeLog: * g++.dg/cpp1y/var-templ-array1.C: New test.
Diffstat (limited to 'gcc')
-rw-r--r--gcc/cp/cp-tree.h2
-rw-r--r--gcc/cp/pt.cc13
-rw-r--r--gcc/testsuite/g++.dg/cpp1y/var-templ-array1.C7
3 files changed, 18 insertions, 4 deletions
diff --git a/gcc/cp/cp-tree.h b/gcc/cp/cp-tree.h
index f46b448..969c723 100644
--- a/gcc/cp/cp-tree.h
+++ b/gcc/cp/cp-tree.h
@@ -3251,7 +3251,7 @@ struct GTY(()) lang_decl {
#define DECL_CONV_FN_TYPE(FN) \
TREE_TYPE ((gcc_checking_assert (DECL_CONV_FN_P (FN)), DECL_NAME (FN)))
-/* Nonzero if NODE, a static data member, was declared in its class as an
+/* Nonzero if NODE, a templated variable, was declared as an
array of unknown bound. */
#define VAR_HAD_UNKNOWN_BOUND(NODE) \
(DECL_LANG_SPECIFIC (VAR_DECL_CHECK (NODE)) \
diff --git a/gcc/cp/pt.cc b/gcc/cp/pt.cc
index 16febb1..9d30a27 100644
--- a/gcc/cp/pt.cc
+++ b/gcc/cp/pt.cc
@@ -22105,9 +22105,16 @@ instantiate_template (tree tmpl, tree orig_args, tsubst_flags_t complain)
DECL_TI_TEMPLATE (fndecl) = tmpl;
DECL_TI_ARGS (fndecl) = targ_ptr;
if (VAR_P (pattern))
- /* Now that we we've formed this variable template specialization,
- remember the result of most_specialized_partial_spec for it. */
- TI_PARTIAL_INFO (DECL_TEMPLATE_INFO (fndecl)) = partial_ti;
+ {
+ /* Now that we we've formed this variable template specialization,
+ remember the result of most_specialized_partial_spec for it. */
+ TI_PARTIAL_INFO (DECL_TEMPLATE_INFO (fndecl)) = partial_ti;
+
+ /* And remember if the variable was declared with []. */
+ if (TREE_CODE (TREE_TYPE (fndecl)) == ARRAY_TYPE
+ && TYPE_DOMAIN (TREE_TYPE (fndecl)) == NULL_TREE)
+ SET_VAR_HAD_UNKNOWN_BOUND (fndecl);
+ }
fndecl = register_specialization (fndecl, gen_tmpl, targ_ptr, false, hash);
if (fndecl == error_mark_node)
diff --git a/gcc/testsuite/g++.dg/cpp1y/var-templ-array1.C b/gcc/testsuite/g++.dg/cpp1y/var-templ-array1.C
new file mode 100644
index 0000000..b0ff7e7
--- /dev/null
+++ b/gcc/testsuite/g++.dg/cpp1y/var-templ-array1.C
@@ -0,0 +1,7 @@
+// PR c++/113638
+// { dg-do compile { target c++14 } }
+
+template<int ...Is>
+constexpr int my_array[]{Is...};
+constexpr auto t1 = my_array<2>;
+static_assert(sizeof(my_array<1>) == sizeof(int) * 1, "");