diff options
-rw-r--r-- | gcc/cp/ChangeLog | 7 | ||||
-rw-r--r-- | gcc/cp/mangle.c | 8 | ||||
-rw-r--r-- | gcc/cp/typeck2.c | 6 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 2 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/cpp0x/initlist12.C | 4 |
5 files changed, 22 insertions, 5 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index cc4fce1..1e85539 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -5,6 +5,13 @@ 2009-01-05 Jason Merrill <jason@redhat.com> + PR c++/38698 + * typeck2.c (process_init_constructor_union): Handle union with + no fields. + + * mangle.c (write_expression): Remove mangling for zero-operand + casts. + PR c++/38701 * decl.c (cp_finish_decl): Clear DECL_INITIAL for invalid defaulting. diff --git a/gcc/cp/mangle.c b/gcc/cp/mangle.c index 1ec27c1..a7b4662 100644 --- a/gcc/cp/mangle.c +++ b/gcc/cp/mangle.c @@ -2348,12 +2348,12 @@ write_expression (tree expr) case CAST_EXPR: write_type (TREE_TYPE (expr)); + /* There is no way to mangle a zero-operand cast like + "T()". */ if (!TREE_OPERAND (expr, 0)) - /* "T()" is mangled as "T(void)". */ - write_char ('v'); + sorry ("zero-operand casts cannot be mangled due to a defect " + "in the C++ ABI"); else if (list_length (TREE_OPERAND (expr, 0)) > 1) - /* FIXME the above hack for T() needs to be replaced with - something more general. */ sorry ("mangling function-style cast with more than one argument"); else write_expression (TREE_VALUE (TREE_OPERAND (expr, 0))); diff --git a/gcc/cp/typeck2.c b/gcc/cp/typeck2.c index e313e4b..60e4ef1 100644 --- a/gcc/cp/typeck2.c +++ b/gcc/cp/typeck2.c @@ -1147,7 +1147,11 @@ process_init_constructor_union (tree type, tree init) tree field = TYPE_FIELDS (type); while (field && (!DECL_NAME (field) || TREE_CODE (field) != FIELD_DECL)) field = TREE_CHAIN (field); - gcc_assert (field); + if (field == NULL_TREE) + { + error ("too many initializers for %qT", type); + ce->value = error_mark_node; + } ce->index = field; } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 9e7d658..7c43f78 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -53,6 +53,8 @@ 2009-01-05 Jason Merrill <jason@redhat.com> + * g++.dg/cpp0x/initlist12.C: Add another test. + * g++.dg/cpp0x/defaulted7.C: New test. 2009-01-05 Thomas Koenig <tkoenig@gcc.gnu.org> diff --git a/gcc/testsuite/g++.dg/cpp0x/initlist12.C b/gcc/testsuite/g++.dg/cpp0x/initlist12.C index 54349bf..31d34c4 100644 --- a/gcc/testsuite/g++.dg/cpp0x/initlist12.C +++ b/gcc/testsuite/g++.dg/cpp0x/initlist12.C @@ -14,3 +14,7 @@ union U }; U u({1,2}); // { dg-error "too many initializers" } + +union V {}; + +V v({1}); // { dg-error "too many initializers" } |