From 9a3c2683a99eee640ea752cfaf5df84d1555de97 Mon Sep 17 00:00:00 2001 From: Jakub Jelinek Date: Fri, 28 Sep 2007 11:29:08 +0200 Subject: [PATCH] re PR c++/31434 (ICE with invalid use of parameter pack in function arg) PR c++/31434 * tree.c (cp_build_qualified_type_real): Handle TYPE_PACK_EXPANSION qualification by creating qualified PACK_EXPANSION_PATTERN and then calling make_pack_expansion on it. * g++.dg/cpp0x/variadic80.C: New test. From-SVN: r128861 --- gcc/ChangeLog | 7 +++++++ gcc/cp/tree.c | 7 +++++++ gcc/testsuite/ChangeLog | 5 +++++ gcc/testsuite/g++.dg/cpp0x/variadic80.C | 28 +++++++++++++++++++++++++ 4 files changed, 47 insertions(+) create mode 100644 gcc/testsuite/g++.dg/cpp0x/variadic80.C diff --git a/gcc/ChangeLog b/gcc/ChangeLog index b2a78e3f5f82..503af66d1a93 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2007-09-28 Jakub Jelinek + + PR c++/31434 + * tree.c (cp_build_qualified_type_real): Handle TYPE_PACK_EXPANSION + qualification by creating qualified PACK_EXPANSION_PATTERN and + then calling make_pack_expansion on it. + 2007-09-28 Jie Zhang * config.gcc (bfin*-linux-uclibc*): Set extra_parts diff --git a/gcc/cp/tree.c b/gcc/cp/tree.c index 11181c2b4256..ca767a18247b 100644 --- a/gcc/cp/tree.c +++ b/gcc/cp/tree.c @@ -773,6 +773,13 @@ cp_build_qualified_type_real (tree type, t = cp_build_qualified_type_real (t, type_quals, complain); return build_ptrmemfunc_type (t); } + else if (TREE_CODE (type) == TYPE_PACK_EXPANSION) + { + tree t = PACK_EXPANSION_PATTERN (type); + + t = cp_build_qualified_type_real (t, type_quals, complain); + return make_pack_expansion (t); + } /* A reference or method type shall not be cv qualified. [dcl.ref], [dct.fct] */ diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index c863096826cd..67e390a623b4 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2007-09-28 Jakub Jelinek + + PR c++/31434 + * g++.dg/cpp0x/variadic80.C: New test. + 2007-09-27 Jerry DeLisle * gfortran.dg/namelist_38.f90: Delete test for revertion of diff --git a/gcc/testsuite/g++.dg/cpp0x/variadic80.C b/gcc/testsuite/g++.dg/cpp0x/variadic80.C new file mode 100644 index 000000000000..a56cdb404c0e --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp0x/variadic80.C @@ -0,0 +1,28 @@ +// PR c++/31434 +// { dg-do run } +// { dg-options "-std=c++0x" } + +extern "C" void abort (); + +template inline int foo (const T...) { return 1; } +template inline int foo (const T *...) { return 2; } + +void +bar (int *a) +{ + a[0] = foo (0); + a[1] = foo (*a); + a[2] = foo (a); + a[3] = foo (2, 3, 4, 5); + a[4] = foo (a, a + 1, a + 2); +} + +int +main () +{ + int a[5]; + bar (a); + if (a[0] != 1 || a[1] != 1 || a[2] != 2 || a[3] != 1 || a[4] != 2) + abort (); + return 0; +}