diff options
Diffstat (limited to 'gcc/cp')
-rw-r--r-- | gcc/cp/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/cp/init.c | 15 |
2 files changed, 10 insertions, 10 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index ce7f829..3234883 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,8 @@ +2002-10-17 Mark Mitchell <mark@codesourcery.com> + + * init.c (expand_default_init): Handle brace-enclosed initializers + correctly. + 2002-10-16 Mark Mitchell <mark@codesourcery.com> * mangle.c (write_expression): Correct handling of enumeration diff --git a/gcc/cp/init.c b/gcc/cp/init.c index 3e71e9f..a7db626 100644 --- a/gcc/cp/init.c +++ b/gcc/cp/init.c @@ -1181,17 +1181,12 @@ expand_default_init (binfo, true_exp, exp, init, flags) to run a new constructor; and catching an exception, where we have already built up the constructor call so we could wrap it in an exception region. */; - else if (TREE_CODE (init) == CONSTRUCTOR) + else if (TREE_CODE (init) == CONSTRUCTOR + && TREE_HAS_CONSTRUCTOR (init)) { - if (!TYPE_HAS_CONSTRUCTOR (type)) - /* A brace-enclosed initializer has whatever type is - required. There's no need to convert it. */ - ; - else - init = ocp_convert (type, - TREE_VALUE (CONSTRUCTOR_ELTS (init)), - CONV_IMPLICIT | CONV_FORCE_TEMP, - flags); + /* A brace-enclosed initializer for an aggregate. */ + my_friendly_assert (CP_AGGREGATE_TYPE_P (type), 20021016); + init = digest_init (type, init, (tree *)NULL); } else init = ocp_convert (type, init, CONV_IMPLICIT|CONV_FORCE_TEMP, flags); |