From 7ad852d0e6cf4a54deb94e2d5fd474047f143e85 Mon Sep 17 00:00:00 2001 From: jason Date: Thu, 25 Dec 2014 07:27:54 +0000 Subject: [PATCH] PR c++/63522 * parser.c (cp_parser_type_parameter): Call check_for_bare_parameter_packs on default argument. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@219066 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/cp/ChangeLog | 6 ++++++ gcc/cp/parser.c | 2 ++ gcc/testsuite/g++.dg/cpp0x/variadic164.C | 12 ++++++++++++ gcc/testsuite/g++.dg/cpp0x/vt-34052.C | 6 +++--- 4 files changed, 23 insertions(+), 3 deletions(-) create mode 100644 gcc/testsuite/g++.dg/cpp0x/variadic164.C diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index cf5ab71..4eb8712 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2014-12-25 Jason Merrill + + PR c++/63522 + * parser.c (cp_parser_type_parameter): Call + check_for_bare_parameter_packs on default argument. + 2014-12-24 Paolo Carlini PR c++/63985 diff --git a/gcc/cp/parser.c b/gcc/cp/parser.c index e57a5bd..2af1576 100644 --- a/gcc/cp/parser.c +++ b/gcc/cp/parser.c @@ -13499,6 +13499,8 @@ cp_parser_type_parameter (cp_parser* parser, bool *is_parameter_pack) "default arguments"); default_argument = NULL_TREE; } + else if (check_for_bare_parameter_packs (default_argument)) + default_argument = error_mark_node; pop_deferring_access_checks (); } else diff --git a/gcc/testsuite/g++.dg/cpp0x/variadic164.C b/gcc/testsuite/g++.dg/cpp0x/variadic164.C new file mode 100644 index 0000000..8f9cdb1 --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp0x/variadic164.C @@ -0,0 +1,12 @@ +// PR c++/63522 +// { dg-do compile { target c++11 } } + +template struct tuple; +template void slice(); +template using slice_result = decltype(slice); +template , + slice_result...>::type> // { dg-error "parameter pack" } +void zip_with(Tuple...); +decltype(zip_with(0)) d; // { dg-error "no match" } diff --git a/gcc/testsuite/g++.dg/cpp0x/vt-34052.C b/gcc/testsuite/g++.dg/cpp0x/vt-34052.C index 1036537..31d2831 100644 --- a/gcc/testsuite/g++.dg/cpp0x/vt-34052.C +++ b/gcc/testsuite/g++.dg/cpp0x/vt-34052.C @@ -1,8 +1,8 @@ // { dg-do compile { target c++11 } } -template struct A {}; // { dg-error "must be at the end" } +template struct A {}; // { dg-error "parameter pack" } -template class U> struct B // { dg-error "must be at the end" } +template class U> struct B // { dg-error "parameter pack" } { - template U foo(); // { dg-error "mismatch|constant|invalid|invalid" } + template U foo(); // { dg-error "mismatch|constant|wrong|invalid" } }; -- 2.7.4