aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPatrick Palka <ppalka@redhat.com>2025-09-12 14:21:25 -0400
committerPatrick Palka <ppalka@redhat.com>2025-09-12 14:21:25 -0400
commit8e3230f4fed0d41e790d68c2534c057911bab35c (patch)
tree9334eddd26d076565493b65cc7d72c707b7c61ce
parentd0c08415310d1daecb28f8fbfeef3d7f18b21d56 (diff)
downloadgcc-8e3230f4fed0d41e790d68c2534c057911bab35c.zip
gcc-8e3230f4fed0d41e790d68c2534c057911bab35c.tar.gz
gcc-8e3230f4fed0d41e790d68c2534c057911bab35c.tar.bz2
c++: pack indexing is a non-deduced context [PR121795]
We weren't explicitly treating a pack index specifier as a non-deduced context (as per [temp.deduct.type]/5), leading to an ICE for the first testcase below. PR c++/121795 gcc/cp/ChangeLog: * pt.cc (unify) <case PACK_INDEX_TYPE>: New non-deduced context case. gcc/testsuite/ChangeLog: * g++.dg/cpp26/pack-indexing17.C: New test. * g++.dg/cpp26/pack-indexing17a.C: New test. Reviewed-by: Marek Polacek <polacek@redhat.com> Reviewed-by: Jason Merrill <jason@redhat.com>
-rw-r--r--gcc/cp/pt.cc4
-rw-r--r--gcc/testsuite/g++.dg/cpp26/pack-indexing17.C11
-rw-r--r--gcc/testsuite/g++.dg/cpp26/pack-indexing17a.C12
3 files changed, 25 insertions, 2 deletions
diff --git a/gcc/cp/pt.cc b/gcc/cp/pt.cc
index 7f0d16f..b7cb807 100644
--- a/gcc/cp/pt.cc
+++ b/gcc/cp/pt.cc
@@ -26301,8 +26301,8 @@ unify (tree tparms, tree targs, tree parm, tree arg, int strict,
case TYPEOF_TYPE:
case DECLTYPE_TYPE:
case TRAIT_TYPE:
- /* Cannot deduce anything from TYPEOF_TYPE, DECLTYPE_TYPE,
- or TRAIT_TYPE nodes. */
+ case PACK_INDEX_TYPE:
+ /* These are non-deduced contexts. */
return unify_success (explain_p);
case ERROR_MARK:
diff --git a/gcc/testsuite/g++.dg/cpp26/pack-indexing17.C b/gcc/testsuite/g++.dg/cpp26/pack-indexing17.C
new file mode 100644
index 0000000..8450ed6
--- /dev/null
+++ b/gcc/testsuite/g++.dg/cpp26/pack-indexing17.C
@@ -0,0 +1,11 @@
+// PR c++/121795
+// { dg-do compile { target c++26 } }
+
+template<class T, class... Ts>
+struct A;
+
+template<class... Ts>
+struct A<Ts...[sizeof...(Ts)-1], Ts...> { };
+
+A<int, int> x;
+A<char, int> y; // { dg-error "incomplete" }
diff --git a/gcc/testsuite/g++.dg/cpp26/pack-indexing17a.C b/gcc/testsuite/g++.dg/cpp26/pack-indexing17a.C
new file mode 100644
index 0000000..445f0d9
--- /dev/null
+++ b/gcc/testsuite/g++.dg/cpp26/pack-indexing17a.C
@@ -0,0 +1,12 @@
+// PR c++/121795
+// A version of pack-indexing17.C using a nontype pack.
+// { dg-do compile { target c++26 } }
+
+template<int N, int... Ns>
+struct A;
+
+template<int... Ns>
+struct A<Ns...[sizeof...(Ns)-1], Ns...> { };
+
+A<0, 0> x;
+A<0, 1> y; // { dg-error "incomplete" }