aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJason Merrill <jason@redhat.com>2012-04-15 23:18:17 -0400
committerJason Merrill <jason@gcc.gnu.org>2012-04-15 23:18:17 -0400
commit56992a78837dbe2180e3d7a75a17289e2897a115 (patch)
tree1ed6cc4d2bf3636d72979de0fec9996bc845d12a /gcc
parentf905751487709b5ef6cde81c5440c4528e7f4390 (diff)
downloadgcc-56992a78837dbe2180e3d7a75a17289e2897a115.zip
gcc-56992a78837dbe2180e3d7a75a17289e2897a115.tar.gz
gcc-56992a78837dbe2180e3d7a75a17289e2897a115.tar.bz2
re PR c++/47220 ([C++0x] no error on unterminated template argument list for variadic parameter)
PR c++/47220 * pt.c (coerce_template_parameter_pack): Check for error_mark_node. From-SVN: r186480
Diffstat (limited to 'gcc')
-rw-r--r--gcc/cp/ChangeLog3
-rw-r--r--gcc/cp/pt.c7
-rw-r--r--gcc/testsuite/ChangeLog3
-rw-r--r--gcc/testsuite/g++.dg/cpp0x/pr39639.C1
-rw-r--r--gcc/testsuite/g++.dg/cpp0x/variadic126.C8
-rw-r--r--gcc/testsuite/g++.dg/debug/dwarf2/pr52260.C4
6 files changed, 23 insertions, 3 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index d37d42c..893ce56 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,5 +1,8 @@
2012-04-15 Jason Merrill <jason@redhat.com>
+ PR c++/47220
+ * pt.c (coerce_template_parameter_pack): Check for error_mark_node.
+
PR c++/52292
PR c++/52380
* pt.c (coerce_template_parms): Even if we aren't converting we
diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c
index 42dc0a7..95d0aba 100644
--- a/gcc/cp/pt.c
+++ b/gcc/cp/pt.c
@@ -6697,7 +6697,12 @@ coerce_template_parameter_pack (tree parms,
TREE_VEC_ELT (packed_types, arg_idx - parm_idx);
}
- if (arg != error_mark_node)
+ if (arg == error_mark_node)
+ {
+ if (complain & tf_error)
+ error ("template argument %d is invalid", arg_idx + 1);
+ }
+ else
arg = convert_template_argument (actual_parm,
arg, new_args, complain, parm_idx,
in_decl);
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index a936b36..321adb3 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,8 @@
2012-04-15 Jason Merrill <jason@redhat.com>
+ PR c++/47220
+ * g++.dg/cpp0x/variadic126.C: New.
+
PR c++/52380
* g++.dg/cpp0x/variadic125.C: New.
diff --git a/gcc/testsuite/g++.dg/cpp0x/pr39639.C b/gcc/testsuite/g++.dg/cpp0x/pr39639.C
index 4fd8b56..0838a0b 100644
--- a/gcc/testsuite/g++.dg/cpp0x/pr39639.C
+++ b/gcc/testsuite/g++.dg/cpp0x/pr39639.C
@@ -2,6 +2,7 @@
// Origin: PR c++/39639
// { dg-do compile }
// { dg-options "-std=c++0x" }
+// { dg-prune-output "template argument 1 is invalid" }
template <class... Types>
struct S
diff --git a/gcc/testsuite/g++.dg/cpp0x/variadic126.C b/gcc/testsuite/g++.dg/cpp0x/variadic126.C
new file mode 100644
index 0000000..513c7e5
--- /dev/null
+++ b/gcc/testsuite/g++.dg/cpp0x/variadic126.C
@@ -0,0 +1,8 @@
+// PR c++/47220
+// { dg-do compile { target c++11 } }
+
+template < typename ... > struct A;
+
+struct B : A < // { dg-error "invalid" }
+{
+};
diff --git a/gcc/testsuite/g++.dg/debug/dwarf2/pr52260.C b/gcc/testsuite/g++.dg/debug/dwarf2/pr52260.C
index 9ab2589..024afc8 100644
--- a/gcc/testsuite/g++.dg/debug/dwarf2/pr52260.C
+++ b/gcc/testsuite/g++.dg/debug/dwarf2/pr52260.C
@@ -22,7 +22,7 @@ namespace A
{
template <typename T>
struct I : H <T> {};
- template <typename ...> struct J;
+ template <typename ...> struct J {};
template <typename> struct K;
struct L
{
@@ -36,7 +36,7 @@ namespace A
template <typename T, typename B2, typename ... B4>
struct N <T (B4 ...), B2> : L::M <B2> {};
template <typename T, typename ... B4>
- struct K <T (B4 ...)> :J <,>, L
+ struct K <T (B4 ...)> :J <>, L
{
typedef T O (B4 ...);
struct P {};