diff options
author | Roger Sayle <roger@eyesopen.com> | 2006-06-12 18:50:22 +0000 |
---|---|---|
committer | Roger Sayle <sayle@gcc.gnu.org> | 2006-06-12 18:50:22 +0000 |
commit | f0b99d6cbdd4809189775194446a6a7093b7162c (patch) | |
tree | 08dd0b278359c4261068a359565a326a12b76c09 /gcc/cp | |
parent | 586825f169eb5672baacf7154df91db0049c508b (diff) | |
download | gcc-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/cp')
-rw-r--r-- | gcc/cp/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/cp/typeck2.c | 7 |
2 files changed, 9 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); } |