PR c++/85049 - ICE with __integer_pack.
authorJason Merrill <jason@redhat.com>
Mon, 26 Mar 2018 14:37:50 +0000 (10:37 -0400)
committerJason Merrill <jason@gcc.gnu.org>
Mon, 26 Mar 2018 14:37:50 +0000 (10:37 -0400)
* pt.c (unify_pack_expansion): Don't try to deduce generated packs.
* cp-tree.h (TEMPLATE_PARM_P): New.

From-SVN: r258856

gcc/cp/ChangeLog
gcc/cp/cp-tree.h
gcc/cp/pt.c
gcc/testsuite/g++.dg/ext/integer-pack3.C [new file with mode: 0644]

index 09cc7dac812444a907413f628aba8de3903ed3f2..011b24e90687f2dd7db984a3b074c4b03b45eac4 100644 (file)
@@ -1,3 +1,9 @@
+2018-03-26  Jason Merrill  <jason@redhat.com>
+
+       PR c++/85049 - ICE with __integer_pack.
+       * pt.c (unify_pack_expansion): Don't try to deduce generated packs.
+       * cp-tree.h (TEMPLATE_PARM_P): New.
+
 2018-03-23  Jason Merrill  <jason@redhat.com>
 
        PR c++/78489 - wrong SFINAE behavior.
index c8f4bc43fa3c39597664b5b66603fcefc7ab0137..db79338035da28c9a86a8556ee3acf367e0a2f00 100644 (file)
@@ -4554,6 +4554,12 @@ more_aggr_init_expr_args_p (const aggr_init_expr_arg_iterator *iter)
        || TREE_CODE (NODE) == TYPE_DECL                \
        || TREE_CODE (NODE) == TEMPLATE_DECL))
 
+/* Nonzero for a raw template parameter node.  */
+#define TEMPLATE_PARM_P(NODE)                                  \
+  (TREE_CODE (NODE) == TEMPLATE_TYPE_PARM                      \
+   || TREE_CODE (NODE) == TEMPLATE_TEMPLATE_PARM               \
+   || TREE_CODE (NODE) == TEMPLATE_PARM_INDEX)
+
 /* Mark NODE as a template parameter.  */
 #define SET_DECL_TEMPLATE_PARM_P(NODE) \
   (DECL_LANG_FLAG_0 (NODE) = 1)
index 9cf03f45e24e50055912d0807b1b9e1976fbb950..d6cce3e67dafd4dcec621d00443893f484764d07 100644 (file)
@@ -20645,6 +20645,11 @@ unify_pack_expansion (tree tparms, tree targs, tree packed_parms,
       tree parm_pack = TREE_VALUE (pack);
       int idx, level;
 
+      /* Only template parameter packs can be deduced, not e.g. function
+        parameter packs or __bases or __integer_pack.  */
+      if (!TEMPLATE_PARM_P (parm_pack))
+       continue;
+
       /* Determine the index and level of this parameter pack.  */
       template_parm_level_and_index (parm_pack, &level, &idx);
       if (level < levels)
diff --git a/gcc/testsuite/g++.dg/ext/integer-pack3.C b/gcc/testsuite/g++.dg/ext/integer-pack3.C
new file mode 100644 (file)
index 0000000..d3ed136
--- /dev/null
@@ -0,0 +1,21 @@
+// PR c++/85049
+// { dg-do compile { target c++11 } }
+
+typedef __SIZE_TYPE__ size_t;
+template<typename _Tp, _Tp... _Idx>
+struct integer_sequence
+{
+  typedef _Tp value_type;
+  static constexpr size_t size() noexcept { return sizeof...(_Idx); }
+};
+template<typename _Tp, _Tp _Num>
+using make_integer_sequence = integer_sequence<_Tp, __integer_pack(_Num)...>;
+template<size_t _Num>
+using make_index_sequence = make_integer_sequence<size_t, _Num>;
+template<typename... _Types>
+using index_sequence_for = make_index_sequence<sizeof...(_Types)>;
+template <typename...>
+struct tuple {};
+template <typename... Ts>
+int get(tuple<index_sequence_for<Ts...>, Ts...>);
+int x = get(tuple<index_sequence_for<>>{});