From: Mark Mitchell Date: Tue, 3 Dec 2002 09:05:36 +0000 (+0000) Subject: re PR c++/8688 (ICE with segfault on missing comma in initializer of 2D array.) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=ee7ecb2924a9995adc324905836cd7207ce43747;p=gcc.git re PR c++/8688 (ICE with segfault on missing comma in initializer of 2D array.) PR c++/8688 * decl.c (reshape_init): Handle erroneous initializers. PR c++/8688 * g++.dg/init/brace3.C: New test. From-SVN: r59768 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index befdf121e2c..2399b18e0e3 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,8 @@ +2002-12-03 Mark Mitchell + + PR c++/8688 + * decl.c (reshape_init): Handle erroneous initializers. + 2002-12-02 Mark Mitchell PR c++/8720 diff --git a/gcc/cp/decl.c b/gcc/cp/decl.c index 1e26b0f112c..d881b832a80 100644 --- a/gcc/cp/decl.c +++ b/gcc/cp/decl.c @@ -7793,6 +7793,14 @@ reshape_init (tree type, tree *initp) old_init_value = (TREE_CODE (*initp) == TREE_LIST ? TREE_VALUE (*initp) : old_init); + /* For some parse errors, OLD_INIT_VALUE may be NULL. */ + if (!old_init_value) + { + my_friendly_assert (TREE_CODE (old_init) == TREE_LIST, 20021202); + TREE_VALUE (old_init) = error_mark_node; + return old_init; + } + /* If the initializer is brace-enclosed, pull initializers from the enclosed elements. Advance past the brace-enclosed initializer now. */ diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 0c51391ad51..af4f57b01dc 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2002-12-03 Mark Mitchell + + PR c++/8688 + * g++.dg/init/brace3.C: New test. + 2002-12-02 Kazu Hirata * gcc.dg/20020210-1.c: Fix a comment typo. diff --git a/gcc/testsuite/g++.dg/init/brace3.C b/gcc/testsuite/g++.dg/init/brace3.C new file mode 100644 index 00000000000..0a1ee8f00a9 --- /dev/null +++ b/gcc/testsuite/g++.dg/init/brace3.C @@ -0,0 +1 @@ +int array[2][1] = { {0} {1} }; // { dg-error "" }