aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorRoger Sayle <roger@eyesopen.com>2006-06-12 18:50:22 +0000
committerRoger Sayle <sayle@gcc.gnu.org>2006-06-12 18:50:22 +0000
commitf0b99d6cbdd4809189775194446a6a7093b7162c (patch)
tree08dd0b278359c4261068a359565a326a12b76c09 /gcc
parent586825f169eb5672baacf7154df91db0049c508b (diff)
downloadgcc-f0b99d6cbdd4809189775194446a6a7093b7162c.zip
gcc-f0b99d6cbdd4809189775194446a6a7093b7162c.tar.gz
gcc-f0b99d6cbdd4809189775194446a6a7093b7162c.tar.bz2
re PR c++/21210 (Trouble with __complex__ types default construction)
PR c++/21210 * typeck2.c (build_functional_cast): Use cp_convert to construct non-aggregate initializers instead of the user-level build_c_cast. * g++.dg/init/complex1.C: New test case. From-SVN: r114573
Diffstat (limited to 'gcc')
-rw-r--r--gcc/cp/ChangeLog6
-rw-r--r--gcc/cp/typeck2.c7
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/init/complex1.C7
4 files changed, 21 insertions, 4 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index d401f88..3dc8225 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,9 @@
+2006-06-12 Roger Sayle <roger@eyesopen.com>
+
+ PR c++/21210
+ * typeck2.c (build_functional_cast): Use cp_convert to construct
+ non-aggregate initializers instead of the user-level build_c_cast.
+
2006-06-07 Volker Reichelt <reichelt@igpm.rwth-aachen.de>
PR c++/27601
diff --git a/gcc/cp/typeck2.c b/gcc/cp/typeck2.c
index 97d5eaa..f4de802 100644
--- a/gcc/cp/typeck2.c
+++ b/gcc/cp/typeck2.c
@@ -1299,12 +1299,11 @@ build_functional_cast (tree exp, tree parms)
if (! IS_AGGR_TYPE (type))
{
- /* This must build a C cast. */
if (parms == NULL_TREE)
- parms = integer_zero_node;
- else
- parms = build_x_compound_expr_from_list (parms, "functional cast");
+ return cp_convert (type, integer_zero_node);
+ /* This must build a C cast. */
+ parms = build_x_compound_expr_from_list (parms, "functional cast");
return build_c_cast (type, parms);
}
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index a4fbcd4..8e5d2c0 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2006-06-12 Roger Sayle <roger@eyesopen.com>
+
+ PR c++/21210
+ * g++.dg/init/complex1.C: New test case.
+
2006-06-11 Eric Christopher <echristo@apple.com>
PR middle-end/27948
diff --git a/gcc/testsuite/g++.dg/init/complex1.C b/gcc/testsuite/g++.dg/init/complex1.C
new file mode 100644
index 0000000..3f88fd9
--- /dev/null
+++ b/gcc/testsuite/g++.dg/init/complex1.C
@@ -0,0 +1,7 @@
+/* PR c++/21210 */
+/* { dg-do compile } */
+/* { dg-options "-O2" } */
+
+typedef float __complex__ fcomplex;
+fcomplex cplx = fcomplex();
+