[pushed] c++: Add fixed test [PR102870]

Message ID 20230131183001.377458-1-polacek@redhat.com
State Committed
Commit b2ec2504af77b35e748067eeb846821d12a6b6b4
Headers
Series [pushed] c++: Add fixed test [PR102870] |

Commit Message

Marek Polacek Jan. 31, 2023, 6:30 p.m. UTC
  This was fixed by r12-7857: now we properly reject instead of
crashing.

	PR c++/102870

gcc/testsuite/ChangeLog:

	* g++.dg/cpp0x/variadic184.C: New test.
---
 gcc/testsuite/g++.dg/cpp0x/variadic184.C | 12 ++++++++++++
 1 file changed, 12 insertions(+)
 create mode 100644 gcc/testsuite/g++.dg/cpp0x/variadic184.C


base-commit: 77906341efc5cb69aada0645c22850bc83c1d42c
  

Patch

diff --git a/gcc/testsuite/g++.dg/cpp0x/variadic184.C b/gcc/testsuite/g++.dg/cpp0x/variadic184.C
new file mode 100644
index 00000000000..458357ac5a9
--- /dev/null
+++ b/gcc/testsuite/g++.dg/cpp0x/variadic184.C
@@ -0,0 +1,12 @@ 
+// PR c++/102870
+// { dg-do compile { target c++11 } }
+
+template <typename> struct integer_sequence;
+template <typename _Tp, _Tp _Num>
+using make_integer_sequence = integer_sequence<_Tp, __integer_pack(_Num)...>;
+template <long _Num>
+using make_index_sequence = make_integer_sequence<long, _Num>;
+template <class> struct Tuple;
+template <int... Is> using type = Tuple<make_index_sequence<Is>...>;
+template <int... Is> void f() { Tuple<type<Is>>{}; } // { dg-error "parameter packs not expanded" }
+int main() { f(); }