From 5621a5d7b10710eb5dac52ee668c711bcc42fa72 Mon Sep 17 00:00:00 2001 From: Jakub Jelinek Date: Mon, 25 Feb 2013 15:41:26 +0100 Subject: [PATCH] re PR c++/56403 (internal compiler error: in build_zero_init_1, at cp/init.c:279) PR c++/56403 * init.c (build_zero_init_1): Use RECORD_OR_UNION_CODE_P instead of CLASS_TYPE_P. * g++.dg/torture/pr56403.C: New test. From-SVN: r196260 --- gcc/cp/ChangeLog | 6 ++++++ gcc/cp/init.c | 2 +- gcc/testsuite/ChangeLog | 5 +++++ gcc/testsuite/g++.dg/torture/pr56403.C | 12 ++++++++++++ 4 files changed, 24 insertions(+), 1 deletion(-) create mode 100644 gcc/testsuite/g++.dg/torture/pr56403.C diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 4a2baa00ad5..eaa43e1e1b7 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2013-02-24 Jakub Jelinek + + PR c++/56403 + * init.c (build_zero_init_1): Use RECORD_OR_UNION_CODE_P instead + of CLASS_TYPE_P. + 2013-02-22 Jason Merrill PR c++/40405 diff --git a/gcc/cp/init.c b/gcc/cp/init.c index 6f46404760e..697f11ff52e 100644 --- a/gcc/cp/init.c +++ b/gcc/cp/init.c @@ -179,7 +179,7 @@ build_zero_init_1 (tree type, tree nelts, bool static_storage_p, init = convert (type, nullptr_node); else if (SCALAR_TYPE_P (type)) init = convert (type, integer_zero_node); - else if (CLASS_TYPE_P (type)) + else if (RECORD_OR_UNION_CODE_P (TREE_CODE (type))) { tree field; vec *v = NULL; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 4be79bec69b..a33bed4e7f0 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2013-02-24 Jakub Jelinek + + PR c++/56403 + * g++.dg/torture/pr56403.C: New test. + 2013-02-25 Catherine Moore Revert: diff --git a/gcc/testsuite/g++.dg/torture/pr56403.C b/gcc/testsuite/g++.dg/torture/pr56403.C new file mode 100644 index 00000000000..27b6eeb8888 --- /dev/null +++ b/gcc/testsuite/g++.dg/torture/pr56403.C @@ -0,0 +1,12 @@ +// PR c++/56403 +// { dg-do compile } + +#include + +struct S { va_list err_args; }; + +void * +foo () +{ + return new S (); +}